/*
 Navicat Premium Data Transfer

 Source Server         : localhost
 Source Server Type    : MySQL
 Source Server Version : 50719
 Source Host           : localhost
 Source Database       : ifast

 Target Server Type    : MySQL
 Target Server Version : 50719
 File Encoding         : utf-8

 Date: 04/08/2018 22:18:52 PM
*/

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
--  Table structure for `act_evt_log`
-- ----------------------------
DROP TABLE IF EXISTS `act_evt_log`;
CREATE TABLE `act_evt_log` (
  `LOG_NR_` bigint(20) NOT NULL AUTO_INCREMENT,
  `TYPE_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_DEF_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `EXECUTION_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `TASK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `TIME_STAMP_` timestamp(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3) ON UPDATE CURRENT_TIMESTAMP(3),
  `USER_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `DATA_` longblob,
  `LOCK_OWNER_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `LOCK_TIME_` timestamp(3) NULL DEFAULT NULL,
  `IS_PROCESSED_` tinyint(4) DEFAULT '0',
  PRIMARY KEY (`LOG_NR_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_ge_bytearray`
-- ----------------------------
DROP TABLE IF EXISTS `act_ge_bytearray`;
CREATE TABLE `act_ge_bytearray` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `DEPLOYMENT_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `BYTES_` longblob,
  `GENERATED_` tinyint(4) DEFAULT NULL,
  PRIMARY KEY (`ID_`),
  KEY `ACT_FK_BYTEARR_DEPL` (`DEPLOYMENT_ID_`),
  CONSTRAINT `ACT_FK_BYTEARR_DEPL` FOREIGN KEY (`DEPLOYMENT_ID_`) REFERENCES `act_re_deployment` (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Records of `act_ge_bytearray`
-- ----------------------------
BEGIN;
INSERT INTO `act_ge_bytearray` VALUES ('110002', '1', '流程审批测试流程.bpmn20.xml', '110001', 0x3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d38223f3e0a3c646566696e6974696f6e7320786d6c6e733d22687474703a2f2f7777772e6f6d672e6f72672f737065632f42504d4e2f32303130303532342f4d4f44454c2220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e63652220786d6c6e733a7873643d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612220786d6c6e733a61637469766974693d22687474703a2f2f61637469766974692e6f72672f62706d6e2220786d6c6e733a62706d6e64693d22687474703a2f2f7777772e6f6d672e6f72672f737065632f42504d4e2f32303130303532342f44492220786d6c6e733a6f6d6764633d22687474703a2f2f7777772e6f6d672e6f72672f737065632f44442f32303130303532342f44432220786d6c6e733a6f6d6764693d22687474703a2f2f7777772e6f6d672e6f72672f737065632f44442f32303130303532342f44492220747970654c616e67756167653d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d61222065787072657373696f6e4c616e67756167653d22687474703a2f2f7777772e77332e6f72672f313939392f585061746822207461726765744e616d6573706163653d22687474703a2f2f7777772e61637469766974692e6f72672f74657374223e0a20203c70726f636573732069643d2273616c61727922206e616d653d22e6b581e7a88be5aea1e689b9e6b58be8af95e6b581e7a88b2220697345786563757461626c653d2274727565223e0a202020203c73746172744576656e742069643d22737461727422206e616d653d22e590afe58aa8e5aea1e689b9222061637469766974693a696e69746961746f723d226170706c79222061637469766974693a666f726d4b65793d222f6163742f73616c6172792f666f726d223e3c2f73746172744576656e743e0a202020203c656e644576656e742069643d22656e6422206e616d653d22e7bb93e69d9fe5aea1e689b9223e3c2f656e644576656e743e0a202020203c757365725461736b2069643d226d6f6469667922206e616d653d22e59198e5b7a5e896aae985ace6a1a3e7baa7e4bfaee694b9222061637469766974693a61737369676e65653d22247b6170706c797d223e3c2f757365725461736b3e0a202020203c757365725461736b2069643d22617564697422206e616d653d22e896aae985ace4b8bbe7aea1e5889de5aea1222061637469766974693a61737369676e65653d2261646d696e223e3c2f757365725461736b3e0a202020203c6578636c7573697665476174657761792069643d227369642d43323842423546362d303133442d343537302d423433322d363142333830433146343646223e3c2f6578636c7573697665476174657761793e0a202020203c757365725461736b2069643d2261756469743222206e616d653d22e99b86e59ba2e4babae58a9be8b584e6ba90e983a8e983a8e995bfe5aea1e6a0b8222061637469766974693a61737369676e65653d2261646d696e223e3c2f757365725461736b3e0a202020203c6578636c7573697665476174657761792069643d227369642d45443436464534312d413046442d343936442d383644432d324339374146353733354630223e3c2f6578636c7573697665476174657761793e0a202020203c73657175656e6365466c6f772069643d227369642d45463246353142422d314439392d344630422d414346322d4236433133303041374432422220736f757263655265663d2261756469743222207461726765745265663d227369642d45443436464534312d413046442d343936442d383644432d324339374146353733354630223e3c2f73657175656e6365466c6f773e0a202020203c757365725461736b2069643d2261756469743322206e616d653d22e99b86e59ba2e4babae58a9be8b584e6ba90e983a8e58886e7aea1e9a286e5afbce5aea1e6a0b8222061637469766974693a61737369676e65653d2261646d696e223e3c2f757365725461736b3e0a202020203c6578636c7573697665476174657761792069643d227369642d46453438354232442d394132332d343233362d424430442d443738384341364533304534223e3c2f6578636c7573697665476174657761793e0a202020203c73657175656e6365466c6f772069643d227369642d33444243443636312d353732302d343438302d383135362d3734384245303237354645462220736f757263655265663d2261756469743322207461726765745265663d227369642d46453438354232442d394132332d343233362d424430442d443738384341364533304534223e3c2f73657175656e6365466c6f773e0a202020203c757365725461736b2069643d2261756469743422206e616d653d22e99b86e59ba2e680bbe7bb8fe79086e5aea1e689b9222061637469766974693a61737369676e65653d2261646d696e223e3c2f757365725461736b3e0a202020203c6578636c7573697665476174657761792069643d227369642d33463533423642442d463846332d343936422d414330382d353036333042443131343737223e3c2f6578636c7573697665476174657761793e0a202020203c757365725461736b2069643d226170706c795f656e6422206e616d653d22e896aae985ace6a1a3e7baa7e58591e78eb0222061637469766974693a61737369676e65653d2261646d696e223e3c2f757365725461736b3e0a202020203c73657175656e6365466c6f772069643d227369642d30324442324144392d313333322d343139382d414338442d3232413335313639443135432220736f757263655265663d2261756469743422207461726765745265663d227369642d33463533423642442d463846332d343936422d414330382d353036333042443131343737223e3c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d32414237433031412d353045452d344141432d384338462d4636453139333542334441372220736f757263655265663d22617564697422207461726765745265663d227369642d43323842423546362d303133442d343537302d423433322d363142333830433146343646223e3c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d33364535304338422d364337432d343936382d423032442d4542414134323542463442452220736f757263655265663d22737461727422207461726765745265663d226175646974223e3c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d37443732333139302d313433322d343131442d413441342d37373432323545353443443922206e616d653d22e698af2220736f757263655265663d227369642d33463533423642442d463846332d343936422d414330382d35303633304244313134373722207461726765745265663d226170706c795f656e64223e0a2020202020203c636f6e646974696f6e45787072657373696f6e207873693a747970653d2274466f726d616c45787072657373696f6e223e3c215b43444154415b247b706173733d3d317d5d5d3e3c2f636f6e646974696f6e45787072657373696f6e3e0a202020203c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d44343443414434332d303237312d343932302d413532342d39423835333345353235353022206e616d653d22e698af2220736f757263655265663d227369642d46453438354232442d394132332d343233362d424430442d44373838434136453330453422207461726765745265663d22617564697434223e0a2020202020203c636f6e646974696f6e45787072657373696f6e207873693a747970653d2274466f726d616c45787072657373696f6e223e3c215b43444154415b247b706173733d3d317d5d5d3e3c2f636f6e646974696f6e45787072657373696f6e3e0a202020203c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d35333235383530322d343345452d344445382d423141342d44424431313932324238414622206e616d653d22e590a62220736f757263655265663d227369642d43323842423546362d303133442d343537302d423433322d36314233383043314634364622207461726765745265663d226d6f64696679223e0a2020202020203c636f6e646974696f6e45787072657373696f6e207873693a747970653d2274466f726d616c45787072657373696f6e223e3c215b43444154415b247b706173733d3d307d5d5d3e3c2f636f6e646974696f6e45787072657373696f6e3e0a202020203c2f73657175656e6365466c6f773e0a202020203c6578636c7573697665476174657761792069643d227369642d35464544303244362d433338382d343843362d383730452d303937444232313331454130223e3c2f6578636c7573697665476174657761793e0a202020203c73657175656e6365466c6f772069643d227369642d31363344424336302d444243392d343338422d393731412d3637373338464237373135412220736f757263655265663d226d6f6469667922207461726765745265663d227369642d35464544303244362d433338382d343843362d383730452d303937444232313331454130223e3c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d37323235384134312d323033452d343238432d423731442d43413335303632353244373322206e616d653d22e698af2220736f757263655265663d227369642d43323842423546362d303133442d343537302d423433322d36314233383043314634364622207461726765745265663d22617564697432223e0a2020202020203c636f6e646974696f6e45787072657373696f6e207873693a747970653d2274466f726d616c45787072657373696f6e223e3c215b43444154415b247b706173733d3d317d5d5d3e3c2f636f6e646974696f6e45787072657373696f6e3e0a202020203c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d38343438454634412d423632452d343839392d414243322d30453244423241453638333822206e616d653d22e9878de696b0e794b3e8afb72220736f757263655265663d227369642d35464544303244362d433338382d343843362d383730452d30393744423231333145413022207461726765745265663d226175646974223e0a2020202020203c636f6e646974696f6e45787072657373696f6e207873693a747970653d2274466f726d616c45787072657373696f6e223e3c215b43444154415b247b706173733d3d317d5d5d3e3c2f636f6e646974696f6e45787072657373696f6e3e0a202020203c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d41373538393038342d343632332d344645412d413737342d30304137304444433144323022206e616d653d22e698af2220736f757263655265663d227369642d45443436464534312d413046442d343936442d383644432d32433937414635373335463022207461726765745265663d22617564697433223e0a2020202020203c636f6e646974696f6e45787072657373696f6e207873693a747970653d2274466f726d616c45787072657373696f6e223e3c215b43444154415b247b706173733d3d317d5d5d3e3c2f636f6e646974696f6e45787072657373696f6e3e0a202020203c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d46413631383633362d333730382d344430432d383531342d32394134424238424339323622206e616d653d22e590a62220736f757263655265663d227369642d45443436464534312d413046442d343936442d383644432d32433937414635373335463022207461726765745265663d226d6f64696679223e0a2020202020203c636f6e646974696f6e45787072657373696f6e207873693a747970653d2274466f726d616c45787072657373696f6e223e3c215b43444154415b247b706173733d3d307d5d5d3e3c2f636f6e646974696f6e45787072657373696f6e3e0a202020203c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d31353235424646342d334539442d344438412d424638302d31463633414645313632383922206e616d653d22e590a62220736f757263655265663d227369642d46453438354232442d394132332d343233362d424430442d44373838434136453330453422207461726765745265663d226d6f64696679223e0a2020202020203c636f6e646974696f6e45787072657373696f6e207873693a747970653d2274466f726d616c45787072657373696f6e223e3c215b43444154415b247b706173733d3d307d5d5d3e3c2f636f6e646974696f6e45787072657373696f6e3e0a202020203c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d33354343384336432d313036372d343339382d393931432d43434639353531313539363522206e616d653d22e590a62220736f757263655265663d227369642d33463533423642442d463846332d343936422d414330382d35303633304244313134373722207461726765745265663d226d6f64696679223e0a2020202020203c636f6e646974696f6e45787072657373696f6e207873693a747970653d2274466f726d616c45787072657373696f6e223e3c215b43444154415b247b706173733d3d307d5d5d3e3c2f636f6e646974696f6e45787072657373696f6e3e0a202020203c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d42444230414142322d374535302d344433352d383045452d4345304245434444394635372220736f757263655265663d226170706c795f656e6422207461726765745265663d22656e64223e3c2f73657175656e6365466c6f773e0a202020203c73657175656e6365466c6f772069643d227369642d34344146423943312d343035372d344334382d423146322d31454338393741353243423722206e616d653d22e99480e6af812220736f757263655265663d227369642d35464544303244362d433338382d343843362d383730452d30393744423231333145413022207461726765745265663d22656e64223e0a2020202020203c636f6e646974696f6e45787072657373696f6e207873693a747970653d2274466f726d616c45787072657373696f6e223e3c215b43444154415b247b706173733d3d307d5d5d3e3c2f636f6e646974696f6e45787072657373696f6e3e0a202020203c2f73657175656e6365466c6f773e0a20203c2f70726f636573733e0a20203c62706d6e64693a42504d4e4469616772616d2069643d2242504d4e4469616772616d5f73616c617279223e0a202020203c62706d6e64693a42504d4e506c616e652062706d6e456c656d656e743d2273616c617279222069643d2242504d4e506c616e655f73616c617279223e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d227374617274222069643d2242504d4e53686170655f7374617274223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2233302e30222077696474683d2233302e302220783d2233302e302220793d223234302e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d22656e64222069643d2242504d4e53686170655f656e64223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2232382e30222077696474683d2232382e302220783d223937352e302220793d223335362e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d226d6f64696679222069643d2242504d4e53686170655f6d6f64696679223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2235382e30222077696474683d223130322e302220783d223230392e302220793d223133352e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d226175646974222069643d2242504d4e53686170655f6175646974223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2235372e30222077696474683d2239362e302220783d223130352e302220793d223232352e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d227369642d43323842423546362d303133442d343537302d423433322d363142333830433146343646222069643d2242504d4e53686170655f7369642d43323842423546362d303133442d343537302d423433322d363142333830433146343646223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2234302e30222077696474683d2234302e302220783d223234302e302220793d223234302e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d22617564697432222069643d2242504d4e53686170655f617564697432223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2238302e30222077696474683d223130302e302220783d223231302e302220793d223333302e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d227369642d45443436464534312d413046442d343936442d383644432d324339374146353733354630222069643d2242504d4e53686170655f7369642d45443436464534312d413046442d343936442d383644432d324339374146353733354630223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2234302e30222077696474683d2234302e302220783d223334352e302220793d223335302e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d22617564697433222069643d2242504d4e53686170655f617564697433223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2238302e30222077696474683d223130302e302220783d223432302e302220793d223333302e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d227369642d46453438354232442d394132332d343233362d424430442d443738384341364533304534222069643d2242504d4e53686170655f7369642d46453438354232442d394132332d343233362d424430442d443738384341364533304534223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2234302e30222077696474683d2234302e302220783d223535352e302220793d223335302e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d22617564697434222069643d2242504d4e53686170655f617564697434223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2238302e30222077696474683d223130302e302220783d223633302e302220793d223333302e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d227369642d33463533423642442d463846332d343936422d414330382d353036333042443131343737222069643d2242504d4e53686170655f7369642d33463533423642442d463846332d343936422d414330382d353036333042443131343737223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2234302e30222077696474683d2234302e302220783d223736352e302220793d223335302e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d226170706c795f656e64222069643d2242504d4e53686170655f6170706c795f656e64223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2238302e30222077696474683d223130302e302220783d223834302e302220793d223333302e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e53686170652062706d6e456c656d656e743d227369642d35464544303244362d433338382d343843362d383730452d303937444232313331454130222069643d2242504d4e53686170655f7369642d35464544303244362d433338382d343843362d383730452d303937444232313331454130223e0a20202020202020203c6f6d6764633a426f756e6473206865696768743d2234302e30222077696474683d2234302e302220783d223234302e302220793d2234352e30223e3c2f6f6d6764633a426f756e64733e0a2020202020203c2f62706d6e64693a42504d4e53686170653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d30324442324144392d313333322d343139382d414338442d323241333531363944313543222069643d2242504d4e456467655f7369642d30324442324144392d313333322d343139382d414338442d323241333531363944313543223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223733302e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223736352e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d33364535304338422d364337432d343936382d423032442d454241413432354246344245222069643d2242504d4e456467655f7369642d33364535304338422d364337432d343936382d423032442d454241413432354246344245223e0a20202020202020203c6f6d6764693a776179706f696e7420783d2236302e302220793d223235352e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d2238322e352220793d223235352e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d2238322e352220793d223235332e35223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223130352e302220793d223235332e35223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d38343438454634412d423632452d343839392d414243322d304532444232414536383338222069643d2242504d4e456467655f7369642d38343438454634412d423632452d343839392d414243322d304532444232414536383338223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223234302e302220793d2236352e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223135332e302220793d2236352e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223135332e302220793d223232352e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d37443732333139302d313433322d343131442d413441342d373734323235453534434439222069643d2242504d4e456467655f7369642d37443732333139302d313433322d343131442d413441342d373734323235453534434439223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223830352e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223834302e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d35333235383530322d343345452d344445382d423141342d444244313139323242384146222069643d2242504d4e456467655f7369642d35333235383530322d343345452d344445382d423141342d444244313139323242384146223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223236302e302220793d223234302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223236302e302220793d223139332e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d41373538393038342d343632332d344645412d413737342d303041373044444331443230222069643d2242504d4e456467655f7369642d41373538393038342d343632332d344645412d413737342d303041373044444331443230223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223338352e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223432302e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d33354343384336432d313036372d343339382d393931432d434346393535313135393635222069643d2242504d4e456467655f7369642d33354343384336432d313036372d343339382d393931432d434346393535313135393635223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223738352e302220793d223335302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223738352e302220793d223136342e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223331312e302220793d223136342e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d32414237433031412d353045452d344141432d384338462d463645313933354233444137222069643d2242504d4e456467655f7369642d32414237433031412d353045452d344141432d384338462d463645313933354233444137223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223230312e302220793d223235362e34313538383738353034363733223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223234312e31343533373434343933333932322220793d223235382e38353436323535353036363038223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d31353235424646342d334539442d344438412d424638302d314636334146453136323839222069643d2242504d4e456467655f7369642d31353235424646342d334539442d344438412d424638302d314636334146453136323839223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223537352e302220793d223335302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223537352e302220793d223136342e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223331312e302220793d223136342e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d33444243443636312d353732302d343438302d383135362d373438424530323735464546222069643d2242504d4e456467655f7369642d33444243443636312d353732302d343438302d383135362d373438424530323735464546223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223532302e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223535352e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d31363344424336302d444243392d343338422d393731412d363737333846423737313541222069643d2242504d4e456467655f7369642d31363344424336302d444243392d343338422d393731412d363737333846423737313541223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223236302e302220793d223133352e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223236302e302220793d2238352e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d34344146423943312d343035372d344334382d423146322d314543383937413532434237222069643d2242504d4e456467655f7369642d34344146423943312d343035372d344334382d423146322d314543383937413532434237223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223238302e302220793d2236352e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223938392e302220793d2236352e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223938392e302220793d223335362e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d42444230414142322d374535302d344433352d383045452d434530424543444439463537222069643d2242504d4e456467655f7369642d42444230414142322d374535302d344433352d383045452d434530424543444439463537223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223934302e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223937352e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d37323235384134312d323033452d343238432d423731442d434133353036323532443733222069643d2242504d4e456467655f7369642d37323235384134312d323033452d343238432d423731442d434133353036323532443733223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223236302e302220793d223238302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223236302e302220793d223333302e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d46413631383633362d333730382d344430432d383531342d323941344242384243393236222069643d2242504d4e456467655f7369642d46413631383633362d333730382d344430432d383531342d323941344242384243393236223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223336352e302220793d223335302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223336352e302220793d223136342e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223331312e302220793d223136342e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d44343443414434332d303237312d343932302d413532342d394238353333453532353530222069643d2242504d4e456467655f7369642d44343443414434332d303237312d343932302d413532342d394238353333453532353530223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223539352e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223633302e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a2020202020203c62706d6e64693a42504d4e456467652062706d6e456c656d656e743d227369642d45463246353142422d314439392d344630422d414346322d423643313330304137443242222069643d2242504d4e456467655f7369642d45463246353142422d314439392d344630422d414346322d423643313330304137443242223e0a20202020202020203c6f6d6764693a776179706f696e7420783d223331302e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a20202020202020203c6f6d6764693a776179706f696e7420783d223334352e302220793d223337302e30223e3c2f6f6d6764693a776179706f696e743e0a2020202020203c2f62706d6e64693a42504d4e456467653e0a202020203c2f62706d6e64693a42504d4e506c616e653e0a20203c2f62706d6e64693a42504d4e4469616772616d3e0a3c2f646566696e6974696f6e733e, '0'), ('110003', '1', '流程审批测试流程.salary.png', '110001', 0x89504e470d0a1a0a0000000d49484452000003f5000001a4080600000070f60582000041bf4944415478daeddd0d8c1ce59927f0de04c246b988a003455cc2127488432b0e21ce882096c842e430c2bb40804c66ec18cb8b30cb01cb121049084712965b874d302c8b96702c211c078b7cc8cbfa7c4e3cb6f1471c234c1071cca70f1cd68c31f6720e3b01db6b92ba7afafa9d2bd7744ff77cba7be6f7935ecdb8bba767dc55ffb7eaa9f7adaa4a05000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000018ad4ff808000000a0f3ccc85b56fb0a000000748873f2b63b6f0b6b5f67fa48000000a0730afa54c8c748fd2e853d000000745641dfec71000000a00dcc6852b8a7e79d630f0000006d58d0372bd88dd8030000401b39a732bc11f8e1be1e00000018c7827ee6087eae5f610f0000009d55d08fd5cf0300000023d0eca27813fd3e000000c0300af1b19a3a6fc41e0000002640f92277bf93b7cb6a5f87a3fc732e9e070000001350d0cf2c14e67f9bb7acf6b5d5c2bed1cf29ec01000060020afa7059ad30cf8651d8170bfad4e6149e778e3d0000008ca1468576bd027da8c2bedeeb1fa8f37ae7d8030000c01816f4338651a8d72bec5b2de8cb85bda9f80000003002ad16d6cd0afbe116f4c5dfbfab62c41e0000004654d0b75a50372aec3f34c2823e718e3d0000008c63413f5461ffca280afad1fe3d00000030a58c7664bc5e613f9a82be5cd83bc71e0000a0937de94b5fcab4f16bf947bc70948b28a6dc9747e85fa93d3e1a0b2d1f4dd3344dd3344dabeeb3436717f53e8571d3ec6af7cd0c3552dfca7dec1b31520f0000ea21acc4b45840f757c6e79cfa9114f6cea9070000f5105662465048b73a32dee8b675f5ae7e3f9cc2ded5ef0100403d8495985114f6cd0aea66f7a16f761ffb46a655dca71e0000d443588919b16623e5cd0afaca080bfb740ac08516010000a887b01233728d46ec5b2de8875bd8a7dfa7a0070000f5105662c6408cd897a7c25f5619fe7de8eb15f6734abfc739f40000a01ec24acc3814f6c58be7150bf4560afa4a939f73db3a0000500f6125661c95a7e247413ea732fcdbd4957f6e86821e0000d443588999f8c27eb4ea4ded070000d443588969f3c27eac0f100000807a08acc4b460b453e64db9070000f5105662daa0b01fee48bb8be20100807a082b316d60b853e84db9070000f51056623ab0b09f96b7febc5de823030000f5105662dac78c5ac13e6388e77729e80100403d849598f6d468c4de947b0000500f8195b8030b7b053d0000a887c04adc8185fd42053d0000a887c04adc617eeff77eef9afc4b2c2bb7ad030000f51058893b6c392df9c217be904d9f3efd109f060000a887c04adc21bababa3e9b2fa7fdb1acbabbbb8dd40300807a08acc41d54d42f8ee5546b1b7d220000a01e022b71672c9f6969943eb5bcc877a13c0000500f8195b80396cf9262419f46eb9d5b0f0000ea21b012b7f7b219344a9f5a7777f7853e210000500f6125b612b7efb25956afa0afb50d3e210000500f6125b612b7e77269384aefdc7a0000500f8195b8bd97cb92a10a7a57c2070000f51058892d2b0000b08f0d56622c2b0000b08f0d56622c2b0000b08f0d5662cb0a0000b08f8d9518cb0a0000ec63839518cb0a0000ec638395d8b2020000ec636325c6b2020000fbd86025c6b2020000fbd86025c6b2020000fbd86025b6ac000000fbd85889b1ac0000c03e365889b1ac0000c03e3658892d2b0000c03e3656622c2b0000b08f0d56622c2b0000b08f0d56622c2b0000b08f0d5662cb0a0000b08f8d9518cb0a0000ec63839518cb0a0000ec638395d8b2020000ec636325c6b2020000fbd86025c6b2020000fbd86025b6ac000000fbd86025b6ac0000c03eb67d6cacc458560000601f1bacc458560000601f1bacc496150000601f1b2b3196150000d8c7062b3196150000d8c7062bb165050000d8c7c64a6c25b6ac0000c03e365889b1ac0000c03e365889b1ac0000c03e3658892d2b0000c03e3656622c2b0000b08f0d56622c2b0000b08f0d5662cb0a0000b08f8d9518cb0a0000ec63839518cb0a0000ec6383957894b22c3be4f5d75f5ff4f4d34fff66e5ca95596f6f6fc7b658569dfcf7af58b1225bbb76ed3fe56db6e40100a01e022b715351d0af5bb72edbb97367b66fdf3eed20b75dbb76656bd6ac79372ff02f913e0000d44360251e528cd02be8dbaeb0dfd7dbdbfb92f40100a01e022bf19062cabd42bafd5a5ed4ef973e0000d44360251e529ccbad886ecba25ee70900807a08acc46353d4fffa576f65af6ffc41f6c28a6f575b7c1f8f29c015f50000a887c04adcc6457dffeebe6cf38f6fc97ebef4c6035a3c16cf29c215f50000a887c04adca645fdb617fe6150419fda9b2f2c51842bea0100500f8195b85d8bfa979efa4ec3a23e9e53842bea0100500f8195b84d8bfacdbddf6c58d4c7738a70453d0000ea21b0122bea35453d0000ea21b0128f65511f57bb6f54d4c7738a70453d0000ea21b012b76951bf65fd5f372ceae33945b8a21e0000f5105889dbb4a87fa76f53b679f9ad83a7dee78fc5738a70453d0000ea21b012b769511f6debb30f0f2aeae33105b8a21e0000f5105889dbb9a8dfbb37dbf2d3bf193cf53e7f2c9e53842bea0100500f8195b80d8bfafedd7dd9abebef69784e7d3c17af51882bea0100500f8195b85d8afabd7bb3b7b6acca7ef1a3af372ce8538bd7c46b8dda2bea0100500f8195f82017f5cd46e78dda2bea0100500f8195b84d8bfa5646e7871ab557942bea0100500f8195f82015f5232de85353942bea0100500f8195f82015f59aa21e000014f5588915f59aa21e0000f510588915f58a7a0000500f819558513f098afaeeeeeeff9caf9b7b24140000f51028eab50e29ea6bc5fcde582f75b00000a8874051af88ee80a2be5ccc2bea0100500f81955851dfe6457dbefefd9798665f2ee615f50000a887c04aaca86fd376c71d7764f546e615f50000a887c04aaca86ff3d6ac98d7344dd3346d74cd5e2ea887b0124ffaa23e9e7bf2c927b33973e6545b7c9fff48f6d4534f8db858ddb3674f76fae9a7575b7abf8b2fbe78e0fb471f7d347be49147aadf6fdfbe3ddbb2654b76fef9e7575bfa1b0e3becb06ccd9a35d9ca952bb3ddbb7757df375ebf6cd9b281df13ffbee9a69b0ef8ddf1d8dd77df5dfdfecd37df3ce0b90d1b36549fdfb66d5b367dfaf46a2bfe9fb76edd7ac0eb376fde5c7d3cfebef877fcee430f3d74589f45fcfcbdf7de3be4f4fb2f7ef18bff355f073f982c3b24360a20472047202f60259ea0a23e8ace458b160d7a6cf1e2c5073cf6dc73cf65175d7451b5a50300e50301d75e7bedc0ebdf7befbd6a8bf789e7fafbfbab8f3ffef8e303afd9b56bd7c06be34040bceee8a38f1e78feb4d34e1b78efd75e7badfaf5e5975f3ee0ef7ce0810706be8fe23bbebef8e28bd992254baadf97ff5ff7dc734ff5fbf87bd2fbbef3ce3bd5ef8b7f5bbd8306f1ef934f3eb9fa37c56756fc5ce36f4d7fef49279d54fd3dcf3efbec0107055ab850de0feb15f7f204b64b801c81bc80a2be61517fe699670e2ad0d7af5f3f68f4bdf8efe38f3fbe5ac4367adfe5cb970fbcd7830f3e58fd1a23e7a79e7a6ab5e03eeeb8e3aa23e5e9f50f3df450f535d1d2cc81785d7a8f380090feae18514f8fdf77df7dd909279c501d45bff9e69b0f786d8ccca7f75fb76e5db674e9d281ff732ab8e3bde2eb0d37dc30e8ff1b8fc7cfc4018d983110330fe277a4f7bff5d65bebfedf3ffad18f565f1f5fe3b38dbfb57870a2d92dedca23f7f204b64b801c81bc80a27e508bc2330acd79f3e61d50d41f75d451d989279e38e4b4f266457d8cbe570a23ec51b4c734fa4a6d24bddec1854a6dea7c8c9cc7f4fc28a2d30181f8994a6dea7cf167a2708f223bfeeefbefbfbffad8d9679f3d5044c7ebe267e2fb871f7eb8fa7fbbfefaeb077e3e4e33a8d4a6c8c78186f4dee9bdaebefaea6a61fdad6f7dabfa78bc2e1d7828fefd51fc178bf7344321a6f0379a11d1a8a84fd2c8bd3c81ed122047202fa0a8af5b4847211fdf47f15d2cb6eb15a1ad16f55194a7e236dee3f0c30faf8ea6c768793c76f9e5970f3a773fbebff3ce3babd3efe3e7d3c87d1c7088afa79c724af53cfbf241834a6d06407926417acff47dfcdf62943f3d9646e2e3c04614fdc71e7b6cf6f9cf7fbefadc8e1d3baa53f1e3ff18457d1c5c88d7c7818673cf3db7fa7f8a9f8d59076fbcf1c6c0ef8a6b05a473f9a3c88fdf577cbe7c20a059512f4f60bb04c811c80b5889872ceae7ce9d5bfd3e46b1a3f81e8ba23e9db35ebe505c3a773d8ae6f2fba7a238fe8e050b1664471c7144f5dcf4bbeeba6b6044be5218a94f23e9a9508f03064315f569c640cc16888bf36ddab469e0d483f4da28dae3fb78be786d81b3ce3aab7ac0210e24c44c82b8585e14f969143ebdb6784e7ef13a01711d80f81ad3f815f5801c811c81bc809578cc8afa34521fdfa769e96351d4c7c8781a8d8f51f718818fabd91f79e49175df3ffe7dc61967547f268ae328b0e3a27431d25d299cfb1e457c14cb515cc7bfa3388f7f17afe05fbc364079543f7e6714ed5198a7a9f7f1581c48a8f7f9c415f9e3cafd710e7e9c92100726e2fcfd782eae1b50afa84f17e14b7f674cf92f8fd22bea013902390279012bf1a88bfa279e786260043d2e4c17056814d2cf3cf3cca8cea98fd1f85458c728774c492f16f2f58afa54f8a673ea2bb5abe6570ae7d447215d3c4f3d5dfdbed9f4fbf49a18fd8f11f3782efe9fe9fb7455fc7a457dfa7fc601859841307ffefcea81814a6116423a7871cc31c754a7eca7f7489f414cf357d40372047204f20256e2312beaa3a591f098e69e2e2a377bf6ec03ae801f056c5c7c2e5a1a058f11f7187d4f17874bd3e1d3efaa146e3117d3cfe3604114bc8d6602544a23f571befa79e79d37e8bd8ab7daabd4a6b4c70c8074a5f87a23f569ea7d5c8d3efd7fe3a041ba805e3a7f3f2eca572eead3ff272ea217af8fbfe38e3beec83ef6b18f0d5c0fa0781781e2cfc7ef88f74e57da2f1f3850d40372047204f20256e26117f531621d23c75154c705e2de7df7ddbaa3d4d75d775dc35bda0dd5d2fbc5a87aa5708bb9f285f88a7f57a5309a9da6cb47315cfe9b8ae7cec7bfe36042bcbed14c84e239f5f1352eb6177f47fceee24c835478177f67a5760e7f1ccc8873fa2fb8e082ea85fb9a7d16714a404cd52ffeade9c0421ad957d40372047204f20256e21115f55a7b34453d20472047202f602556d42beae509e40890239017acc48a7a4d512f4f20472047202f602556d46b8a7a408e408e405ec04aaca857d4cb13d82e017204f2028a7a4d512f4f2047204780bc602556d46b8a7a1b05902390239017b0122bea15f5f204c811c811c80b588915f58a7a79023902e408e4052bb1a25e53d4cb13c811c811c80b588915f59aa21e902390239017b0122bea15f5f204b64b801c81bc80a25e53d4cb13c811c811202f588915f59aa2de4601e408e408e405acc48a7a45bd3c0172047204f20256e292952b572aa2dbafedc98bfafdf204c811c811c80b588987b476eddab776eedca9906ea3d6d7d7f7777951ff923c0172047204f20256e221ad5ab5ea82d5ab57ffeaedb7df7e5f417df047e8a3a05fb162c51b79bb449e003902390279012b7153790139b3b7b777634cf98e73b93bb13df6d863592cab4efdfb6b2d3eff97266b416fa30072047204f20256621a2da725b1aca64f9f7e884f439e408e00390279012b7187e8eaeafa6cbe9cf6c7b2eaeeee9ee11391279023408e405ec04adc3945fde2584eb5b6d127224f2047801c81bc8095b83396cfb4344a9f5a5ee4cff4c9c813c8112047202f60256effe5b3a458d0a7d17ae7d6cb13c8112047202f60256eef653368943eb5eeeeee0b7d42f2047204c811c80b56622b71fb2e9b65f50afa5adbe01392279023408e405eb0125b89db73b9341ca5776ebd3c811c017204f20256e2f65e2e4b862ae85d095f9e408e00390279012bb16585650472047204f20256622c2b2c23902390239017b012635959462047801c81bc8095d8b2c2320239023902e4052b3196159611c811c811c80b5889b1ac2c23408e408e405ec04a6c596119811c017204f2829518cb0acb08e408e408e405acc45856961120472047202f6025c6b2b28c408e00390279012bb16585650472047204c80b56622c2b2c2390239023901738182bec9258699bb48d3e291d0e9611c811c811c80bb4df0a3b2d6ffb872aeabbbaba66faa47438584620472047202fd09e2bedb2218afa0dd3a74f3fc4a7a4c3c13202390239027981f65c69a7352aeabbbbbb2ff409e970b08c408e408e405ea0bd57dc7ae7d66f344aafc3c13202390239027981f65f71079d5bef5c7a1d0e9611c811c811c80b7488bc885f6c945e8783650472047204f2029d59d47fb6702efd0c9f880e07cb08e408e408e4053a6b05ae9e5b6f945e8783650472047204f2029db7024fb312eb70b08c408e408e405e98b2b22c3be4f5d75f5ff4f4d34fff66e5ca95596f6f6f47b558893bed6f5eb16245b676edda7fcadb6c1d0e9611c8112047202f8c5814f4ebd6adcb76eedc99eddbb74f9ba0b66bd7ae6ccd9a35efe605fe253a1c2c239023408e405e189118a157d01fb4c27e5f6f6fef4b3a1c2c239023408e405e18919872afc03e782d2feaf7eb70b08c408e003902796144e21c6fc5f5412dea331d0e9611c8112047202f8c6b51ffeb5fbd95bdbef107d90b2bbe5d6df17d3ca63057d4eb702c23408e408e405e68e3a2be7f775fb6f9c7b7643f5f7ae3012d1e8be714e78a7a1d8e6504c811c811c80b6d5ad46f7be11f0615f4a9bdf9c212c5b9a25e8763190172047204f242bb16f52f3df59d86457d3ca73857d4eb702c23408e408e405e68d3a27e73ef371b16f5f19ce25c51afc3b18c0039023902794151afa8d7e16019811c811cc911c80b6359d4c7d5ee1b15f5f19ce25c51afc3b18c003902390279a14d8bfa2debffba61511fcf29ce15f53a1ccb08902390239017dab4a87fa76f53b679f9ad83a7dee78fc5738a7345bd0ec73202e408e408e485362deaa36d7df6e141457d3ca63057d4eb702c23408e408e405e265c9665bfbb69d3a6f93ffce10fd72c58b0e0dd6bafbd76ffdcb973b3f85066cf9efddb3ff9933fd977f3cd37bffe9def7ce791bcfdbb295dd4efdd9b6df9e9df0c9e7a9f3f16cf29ce15f52d9851eb7066e87a6d14408e00390279195531ffc4134f3c7cdb6db7edbfeebaebb2ef7ffffbd9d34f3f9df5f5f5657bf6ecc9427cddb97367f6b39ffd2ccb8bfeec4ffff44f7ffb677ff667bfbce28a2b2e9f6a457dffeebeecd5f5f7343ca73e9e8bd728d015f54338276fbbf3b6b0f675a6eed74601e4089023909761cb8bf7797ffee77fbef7c61b6fac16ec1f7cf041d6aae79f7f3efbea57bffac1fcf9f35fbaf4d24b8f9ff445fddebdd95b5b5665bff8d1d71b16f4a9c56be2b546ed15f54314f4a9908f91fa5d0a7b1b059023408e405e5a96d7e4873cf9e493abaebcf2ca6cc99225c32ae6cb7ef4a31f65f3e6cd7b7fb28cdad72bea9b8dce1bb557d48fb0a06ff638360a2047801c81bc0c2ee857af5efdcc35d75c93bdfaeaabd958f8e52f7f995d79e595ef5f7ef9e5ff693216f5ad8cce0f356aaf5857d457fedf88fc50857b7ade39f6360a2047801c81bc341623f451d0c739f26329deef8a2baee8efeeee9e3dd98afa9116f4a929d6a77c51df6ac16ec4de4601e40890239097c6e21cfa98723f5623f4f546ece7cc99b33b2fec4f9c4c45bda6a81f85732ac31b811feeebb1510039023902a6425ee22af7dffef6b7f7c539f4e369e9d2a5efcf9a356b83a25e53d48f78e43d7eae5f616fa3007204c811c8cb80c58b17fff7b8cafdbffccbbf64e3edaaabaedad16ed3f0f3bfa7376f7fa0a857d4b779413f563f8f8d02c811c811c8cb6411a3f4711ffab86ddd44f8f9cf7fbeafdd46eb63e1468be2beababebb38a7a45fd386a7651bc897e1f6c14408e408e405e3ad9a64d9be6c7c5f14673ebbae19a376fde8efc03fd4cbb15f585b6acdec8bda25e513f4685f8584d9d37626fa300720472244730d5f3f2c31ffe70cd030f3c904da4850b173e9f7fa037b471513f30725f2cee15f58afa3128c05341ff3b79bbacf67538ca3fe7e279360a20472047c054cecb82050bde7dfae9a727b4a8ffe94f7ffacbfc035dd2ee457d71e43ea6e52bea15f5a32ce867160af3bfcd5b56fbda6a61dfe8e714f6360a20472047c054cdcbb5d75ebbffadb7de9ad0a27ec78e1d3bf30f74db412ad047dc14f553b3a88f0b3b8ee274917a53e42fab15e6d9300afb62419fda9cc2f3ceb1b7510039023902a6625ee6ce9d9bedd9b367428bfaf87df907baa75d16d41085fcc6aeaeae99d3a74f3f245e3792a23efeafa79f7e7ab53df9e493d562ece28b2f1ef8fed1471fcd1e79e491eaf7dbb76fcfb66cd9929d7ffef9d53667ce9ceaeb0e3becb06ccd9a35d9ca952bb3ddbb7757df375ebf6cd9b241bf6ff3e6cdd5e7d6af5f3fe4df15a75c2c5dbaf480c7e2e7162f5e5cf7f5f1f8e38f3f3ea2623cdef7bbdffd6ec716f53153236ffd79717f5d9e97df1dc68f362ab4eb15e84315f6f55eff409dd73bc7de4601e408e408986a7989ffd8c1309e23ea6350d41f50cc27231da97fefbdf7aa2d0ae328c8fafbfbab8f178be45dbb760dbc360e04c4eb8e3efae881e74f3bedb4810301afbdf65af5ebcb2fbfdcb0608fe7df7cf3cd210bed134e38a1fa9e9ffad4a7b2679e7966d00187f85be240c3d9679f3df0d829a79c523d7010ff2eb638f0f0ecb3cf56df3b0e40c463e9a044fc3fce3aebac81d73ef1c413d971c71dd74945fd538575635bbe6e7c691805fd8c6114eaf50afb560bfa72616f2abe8d02c811c8113015f272d96597fd76a247eadf7ffffd1de335523fd2855b6b1bbabbbb2f2c17f3a32dea972f5f3e50143ff8e0830305f7a9a79e9a2d59b2a45ae0e6bf73e0f50f3df4d04001978ae3785d7a8f380050298cc647311dc5782ac8e3e0c119679c915d79e595033f13dfa7f77ff8e187ab8579fc2d3133e0a9a79e1a38c010af8de7cb0725d2cfdd77df7dd5830ee9b58b162d1af8bef81ec50316f1efdb6ebb6de0df871e7a68f6b5af7d6d589fe1debd7bb39e9e9e5846efe4edd5bcfd34aecb90b787f265f6bdfcebd7f37645fefdc5f9d7e9b366cdfaf7f9d77f73de79e71d3606ebc7963a077e96e4bfe3d3a32cac9b15f6c32de88bbf7f57c588bd8d02c811c81130f9f372cd35d7ec9be873eab76fdffeca789d533fc2855b77647eac8afa288a2b8511f628da631a7d7cffe28b2fd61d458f76f7dd7767efbcf34e757a7e4cdf4f0704e267e2ebb66ddb06a6f8177ffef8e38faf8eec37fa7b62a43c8afd183d8ff78c02fba8a38eaa3e76e28927564f09a89446fae3fb78ecb9e79e3be0c0429aae1fdfc7df19dfc74c843855208dccc773f3e6cdab7e7fd14517550f528c74fa7dfeb3ff3a5f5627e4c5fb19b1ccf2653737fffe2bf9d7ff92b7efe78ffd8ffcebeabcfd226fdbf3b62fa6cee72d2ecef8b3bc2dcfdba379bb276fdfcc7ff69afc6b4ffe73ffb1a7a7e73fc4b9f37ff4477ff4f1d2fad1df6056483cfe8db973e77ea24e41df6a41dda8b0ffd0080bfac439f6360a20472047c054c8cb2db7dcb265a2af7effe31ffff87fb5d3d5ef5b3592a23e8af254d8c6a8f6e1871f5e9df6be6eddbaea63975f7ef9c0f331629e0ae43befbcb33a6d3d7e3e8ddc47615ca94d818fe9ee8d7ee75045fd8e1d3baaef1123f5f1be6926409a2a7fecb1c70e1c348851fc7450e2da6bafcd3efef18f677ff8877f582df0e3b974a0a2d1e87c71143fde3bbe8feb00c4673091e7d45f7ae9a5ff2a8af528daa378cf0bf9eefcebd551d4d78afb28f27f9cb7676bc57f7fed60c0f6dac181214ff7c8dfebadfcbdbf7cc821877c7e848574bdc2fe955114f4233dc0808d02c811c811c84ba7f9cbbffccb0726fa3ef5b7de7aebd276ba4ffd7816f569e43a15b7f7de7bef40b11fff4e45762a80d3eb62b43ca6bb2f58b0203be28823b2934e3a29bbebaebbaacf6dd8b0e18091fa54f0c60182289a3ff9c94f565b14d2f7df7fffc0f9f1e9b5efbefbeec0ef89e23f15f431825f2cd4ebcd3248c57e9c677feeb9e71ef037978bfa33cf3c73d0487d1ca8b8e0820bdafe4279975e7ae94766cf9e7d744ce56f52d47f90b75f7dee739ffbf5473ef291ecc31ffef01f8ef057d62bec4753d0970b7be7d8db28801c811c81bc4c46dff8c637feedd5575ffd9b0f3ef860c22e7edfd3d3f3da286e11d671457d8c7ca7e23646c7a3b08d8bc91d79e4918346b5d3bfe39cf8f8992894635afbc9279f9cbdf1c61bd5e7b66edd3ae80af7319d3f15eecda6dfd71b4d4fd3f8e38279c5d7a4023f0e4ca4030a31a320be7ffef9e70f28fcd368fc6428ea0bc1ff4c83627e6b8cf4d7ceab8fe9f7d9873ef4a1bb46f9eb62ca7d7984fe95dae3a3b1b0f65e9fd095db28801c811c81bc4c42d75f7ffdfffed9cf7e365153ef1fc93fcc759df8398db4a88fd1f854dcc6b4fa747e7a717a7ab9a84f05723aa7be52bb6a7ea5704e7d5c806fb8d3efcb457d1aa94fa3f57111bb54ac97671b546a57dc4fb30b366dda547d2e1eabd4a6f4a7d7176fb757fcffc46beb5d47a05d8bfaeeeeee3f2814f2fbf3f6dff2c766d4b9fe42b3abdd3733d4487d2bf7b16fc448bd8d02c811c81130d9f3f2c77ffcc7977ee52b5fd93f01a3f5bb7b7a7a9ecb8ba2d953a9a8afd4a6aca7a2382e4a77cc31c7341c31af9446eae32af9e79d77dea0f78a8bd4c514fc98061f2d15e631032046c4d385ead205f6627640b3a2bed2e01ef7e9c27ec5ff471c708851fa38e8902e92d7e8ff5f1cc5efa4fbd4e7c1bfa4761bbb85f97a7b620b05747f657ccea91f4961ef9c7a1b059023902360aae465fefcf99be2b669e329cedf8f51fa6657999f4c457d3a7f3d46d52b85abc61747abe3dfc5f78e7fc7d5e38b53dbd33de08baf898bedd5bbfafd700e36c4322f3f56afa84fd700983b77eec0ff29feb6749eff50457b2717f579217f64fe7ffedd1114d2ad8e8c37ba6d5dbdabdf0fa7b077f57b1b0590239023602ae525ce1d9e376fdefbafbefaeab814f49b366d7a32ff1d6fb530da39a98a7a6decdac128ea47a8d511f266f7a16f761ffb46a655dca7de4601e408e408987a79993d7bf6acf9f3e7bfb773e7ce312de8df7cf3cd9ff4f4f4bcd1a9d3ee15f58afa11683652deaca0af8cb0b04fa7005ca8dbb6510039023902a6605e66cd9a35ef8a2baee81fab11fb18a18f82beababebab9dfed928ea15f5c3d468c4bed5827eb8857dfa7d0a7a1b0590239023602ae7252fc0bf347bf6ec77fffeeffffed7a3b878deeeef7def7b3f8829f7799b3b193e1745bda27e0462c4be3c15feb2caf0ef435fafb09f53fa3dcea1b7510039023902e465e03ffc999e9e9e95f3e7cfdff1dc73cfbd3f9cfbd02f5fbefcb1d9b3676f8c8be275f239f48a7a45fd1816f6c58be7150bf4560afa4a939f73db3a1b0590239023405e1afec72f89e27eeedcb93b172c58f0c24f7ef29337fafafade8a2bae87f7df7f7fc7f6eddb5f59b162c5fffce637bfb96cd6ac59af47311fa3f39d7a957b45bda27e1c94a7e247413ea732fcdbd4957f6e8682de4601e408e4089097a6f262fdd3ddddddd7e51fc4a2bc6dcddb9ef8506a5fb7e56d49de6e8811fec9fa1928ea15f5635cd88f56bda9fdd828801c811c01f282a25e51dfe685fd581f20c04601e408e408e40545bda6a86fc168a7cc9b726fa3007204c811c80b8a7a457d1b14f6c31d6977513c1b059023408e405e50d42beadbc070a7d09b726fa3007204c811c80b8a7a457d0716f6d3f2d69fb70b25d14601e4089023901714f58afaf631a356b0cf18e2f95d0a7a1b059023408e405e50d42beadb53a3117b53ee6d14408e003902794151afa8efc0c25e416fa3007204c811c80b6365e5ca958aeb83d7f6e445fdfe29b09aa5427ea182de4601e40890239017c6d0dab56bdfdab973a702fb20b4bebebebfcb8bfa97a6c8aa36a3d6e1b86d9d8d02c8112047202f8c9555ab565db07af5ea5fbdfdf6dbef2bb4276e843e0afa152b56bc91b74b743858462047801c81bc3062796139b3b7b777634c058f73bcb5716ff139bf34950a7a1d8e65047204c811c80ba0c3c1320239023902e405d0e16019811c811c81bc00e8702c23408e408e405e001d0e9611c811c8911c81bc003a1c2c23902390239017001d8e6504c811c811c80ba0c3c132023902e408e405d0e16019811c811c81bcc80ba0c3c13202390239027901d0e15846204772047204f202e870b08c408e408e0079017438584620472047202f003a1ccb0890239023901740878365047204c811c80ba0c3c13202390239027901d0e158469611c811c811c80b800ec732023902e408e405d0e16019811c811c01f202e870b08c408e408e405e007438961120472047202f800e07cb08e40890239017408783650472047204f202a0c3b18c00390239027901d0e158462047801c81bc003a1c2c2390239023405e001d0e9611c811c811c80b800ec73202e408e408e405d0e16019811c017204f202e870b08c408e408e405e007438961120472047202f003a1ccb08e40890239017408783650472047204c80ba0c3c13202390239027901d0e15846801c811c81bc003a1c2c2390239023405e001d0e9611c811c811c80b800ec73202e408e408e40598329dcb92e8609ab48d3e291b059023408e405e80f6eb5ca6e56dff50457d5757d74c9f948d02c8112047202f407b7630cb8628ea374c9f3efd109f928d02c8112047202f407b7630d31a15f5dddddd17fa846c14408e0039027901dabb93a9776efd46a3f4360a2047801c81bc00eddfc90c3ab7deb9f4360a2047801c81bc001d222fe2171ba5b751003902e408e405e8cca2feb38573e967f8446c14408e00390279013aabb3a99e5b6f94de4601e40890239017a0f33a9b693a1c1b059023408e405e60cac9b2ec90d75f7f7dd1d34f3ffd9b952b5766bdbdbdda04b7152b56646bd7aefda7bccdb65190234d8ee4488ee4488ee4488ee405685974fcebd6adcb76eedc99eddbb74f3b486dd7ae5dd99a356bdecd370497d88992234d8ee4c8fa2c4772244772242f404be248ae8ebf6d3600fb7a7b7b5fb21325479a1cc991264772244772242f404b626a968eb77d5adef9efb71325479a1cc991264772244772242f404be2dc1f9d6e5b75fe93b6e39ccc1b0539922339922339922339d226638e14f530893aff5fffeaadecf58d3fc85e58f1ed6a8befe3311db6cedf46418ee4488ee4488ee4488e34453dd0c69d7fffeebe6cf38f6fc97ebef4c6035a3c16cfe9b475fe76a2e4488ee4488ee4488ee44853d4036ddaf96f7be11f0675fca9bdf9c2129db6cedf4e941cc9911cc9911cc9911c698a7aa05d3bff979efa4ec3ce3f9ed369ebfced44c9911cc9911cc9911cc991a6a807dab4f3dfdcfbcd869d7f3ca7d3d6f9db8992233992233992233992234d510fe8fc75fe76a2e44893233992233992233992237901c6b2f38faba236eafce3399db6cedf4e941cc9911cc9911cc9911c698a7aa04d3bff2debffba61e71fcfe9b475fe76a2e4488ee4488ee4488ee44853d4036ddaf9bfd3b729dbbcfcd6c153b4f2c7e2399db6cedf4e941cc9911cc9911cc9911c698a7aa04d3bff685b9f7d7850e71f8fe9b075fe360a72244772244772244772a429ea8176eefcf7eecdb6fcf46f064fd1ca1f8be774da3a7f3b5172244772244772244772a429ea8136ecfcfb77f765afaebfa7e1b957f15cbc46c7adf3b71325477224477224477224475ae7e628cfc692c84793b65105059dd2f9efdd9bbdb56555f68b1f7dbd61c79f5abc265eebe8ae9d283b5172244772244772244772a4756c513f2d6ffb872aeabbbaba66aaa0a0033aff6647711dddd5f9db8992233992233992233992236df2e528cfc7b2218afa0dd3a74f3f4405051dd0f9b7721477a8a3bb3a713b5176a2e4488ee4488ee4488ee4488e3ab2a89fd6a8a8efeeeebe50f5041dd2f98fb4e34f4d276e27aa8e19b59da81972244772244772244772244772d4d6857dbd73eb371aa5870eeafc359dff183b276fbbf3b6b0f675a61c6972244772244772244772d4b645fda073eb9d4b0f3a7f6deaee449d53da718a91915d936d474a8ee4488ee4488ee4488eb4c994a3bc885f6c941e74fe9a9da8731a8c849c33d94648e4488ee4488ee4488ee4489b6445fd670be7d24fcad3554051afe9fc8736a3c98e527a7e861c6972244772244772244772d47ed2b9f546e941e7af4dbd9da856779026cd08891cc9911cc9911cc9911c699d9ea359b3667dbaababebeabc905f94b72d797baf365abf276f5b6b53f26f88d7a9a240e7af4dde9da8738639e231dcd7cb91264772a4c9911cc9911c8da1b8555dde7af3b66f887bd497db53f9eb67aba640e7af4dae9da8918e74c4cff577f28e941cc9911cc9911cc9911c699d96a3bc30ff4c5e98ff6818857cbdb6eed24b2f3d5e55053a7fadf377a2463b75b1a3a73eca911cc9911cc9911cc991d64939eaeaeafa524f4fcfff2916e8b366cdcafee22ffe225bb56a55f68ffff88fd93ffff33f67e1bdf7decbfafafab2f5ebd7670b172eccbefce52f970bfb7ea3f6a0f3d73a7b27aad9458826fa7de4488ee4488e343992234d8e1a17f433f322fc836231ffc8238f643b77eecc5ab17bf7eeeaebe3e78ac57dfe9e97abae40e7aff3efbc9da8b1be6a70478e90c8911cc9911cc9911cc991d609398a11fa62417ffdf5d75747e547227eeec61b6f2c17f646ec41e7aff3efa0d5a77c51a1dfc9db65b5afc351feb98ebb58911cc9911cc9911cc9911c69ed9ea33887be38e5fed65b6f1d98623f523135fff6db6f2f4fc53f5195053a7f9d7fe7ec40cd2cec08fd6ddeb2dad75677a41afd5c47ed48c9911cc9911cc9911cc991d6ee39ca0bfa15c511fad116f4c5c2be3462bf4e95053a7f9d7f67ed40556a231b59a1b5b22355dc814a6d4ee1f98e39a7518ee4488ee4488ee4488eb476ce51dcb6ae780efd48a7dc0f3515bf788ebd69f8a0f3d7f9b7af463b36f5768886da91aaf7fa07eabcbe23ce699423399223399223399223adcd8bfade5470c745eec6c3638f3d66b41e3aa1f38f8ddd860d1bb2975f7eb9fafdf6eddbebbeeed9679fcd2ebef8e26a9b33674ef6e4934f66175d7451366fdebceaf78b172faefefc50bfa7a7a7a7e5bfebf8e38fcf4e3ef9e486cf6fddbab5fa9ecf3cf34c758ad0030f3c901d71c411d90d37dc50fd7bd2ff2bbdfea9a79e1af8fbe2f968f1ff482dfdcc830f3e38e8efbee38e3b0ee8cce3ff11affff8c73f9e6ddebcf9a077fed1a9e7ed0f46b1033563183b46f576a45add812aef484df8d4c7563f2b399223399af81c699d5f8cc8911cc9d1c4ac1bb366cdfa74ba385e8ca6bff3ce3be352d4c755f14bb7bbfb8c6a0bdaaca84f05c8e73ffff9819df1cb2fbfbcfafd91471e99dd79e79d03af3dfcf0c3b30b2eb8e0809fffd4a73e954d9f3ebdfa7d7f7f7fd362e4ecb3cf6ef96ffbe4273f999d75d65943be260a92356bd664cb972fcf962c59522d989e7beeb96cc78e1dd5dfb769d3a6417fc3d2a54bab5fa33889c7a260897fbff1c61b07bc36de373e87db6ebbadfafce38f3f5efdbf464b055b3c1e47460f76e75f9816d5dbd5d5f5d9167facd51d99663b52c3dd812afefe5d133d42d2ea672547722447139b236d721423722447723431eb46fef8d5e97571d07c3cc57dec0b45fd0daa2d68b3a23e6df4d2885b7cffc52f7e71e0fb3d7bf61c508c2c5bb62c9b3d7b76b5c56b6244efd8638fcdbef5ad6f5577fc9b1523471d7554c3e763073f8a9568f1de871e7a6876dc71c70dfc6d8b162d3ae0fdd7af5f5ffdf7c30f3f5c2daad2ef38e18413aa472b8beffdda6baf55bfeedab56b60a4f1cd37dfacfeec873ffce1eafbc7ff3b5afa9928aee277a47fc7ff3dfd8e2d5bb6549f4b8fb54be75f68cb9a1ce11dee94c3463b521f1ae10e54796466c276a45afdace4488ee4686273a44dae62448ee4488ec677ddc81f5b949e5fbd7af5b816f5b1ad2efc2d4b545bd046457d141731d536a6be16a7dac6b4d998021cc540f9f531c2185374e3dff1355efffbbffffb4d4718a3a889e70e3becb021ffa662f1531ebd4b2383e562e4dd77dfad1607f1fd2db7dc522d44e2fb534e39a55a70a462241e8b29be5140546ad3a3e3eb69a79d56fdbf1f7df4d1d979e79d37a8808a29c5698a728c42a66224be6edbb6ad5d3bff8123bc757610467a0e61bd1da95746b10335dabf675c3f2b399223399ab81c6993ba1891233992a3715837f27f6f498f8ff505f2cafafafa8a7fc736d516b449511f3bd1513cc44e782a26d2ce778ce4352a5e8ad3866fbef9e6ea88617c6d568ca4a9b93122592c389a8d7e168b91f8bb623433fd3bce017ee8a187aa238aa9a048e7f4de7df7ddd5f388bff6b5af1df07e575d75d54061910a9428bcd20862fc1fd36867bccf49279d94dd73cf3dd9c73ef6b1ec89279ea8fefe134f3cb1fafcca952b074d356eb7cebf7884b7367d6bb42311f576a446b30355de919ad12e9f951cc9911c4d4c8eb4a9518cc8911cc9d1d8ae1b797b3ffd7bac6e6337d4eded0abf7b8f6a0bda68a43e5aec60c7a8df75d75d5777da703c5faf18899df3385736a6f84601d0ac18a9d4ce032e5e646ba8168546a536b5373d1685cfe73ef7b9035e572ca6e2f7177f5f2a32ca7f471a254cd39c8b238cc5622b462aa3f038f7dc7307a631a751c938f738bd5fb3a9c32d74cc13d2bef0852fa49d9d85a35cc53e546744e495dae3a3b1b05d3eab687224477234b139d2c6bfc9911c69932747c536118abf4fb5056d52d4c7285bec60c705bae2ead8f17d4cb98d0d628cca15af629dce874de702c745b7d28e7e8c00c6eb862a46d294e17435ecf87ec182054d47176364afde14de46c5483c7fe699670e7c5f2ca4629a6ffc3b1e4f7f674c218ecf2afd3b2e32521c318ce9c8e5c223153069e4b3d26617f8aad336767575cd9c3e7dfa21b59736bbbaf06846465ab96f703b8f8c1cf059c9911cc9d1c4e468a2ee2011b34a8a7f4fbce6f6db6faffb3b627d8de763742a4e5949bfe7fcf3cfcfe6ce9d3ba60542fc9eef7ef7bb4d5f13a7f7c4f771b1c93453a795ecc8d1d4ca51bd6dc7e9a79f5e6d697b14d949df3ffae8a3d57528652efaf958cfa3a5f53e0e5ac701e89859155742af773036fe7dd34d370d5a6f63c6577c5f3cb85c9c791633ded2c5538bdbccd8bed6cb65baf64b7afff28567e3fdd23564625b16d7ae890bc01667a1556ad791e9d091fa817523ffbedf483d4cf1a23e3af9e2f4dd280e62fa6d9c0b5b6f642e5a4c994d3bfeb1a37efffdf7573bc6b8aaf550c548b98878fef9e787ec50d32867bdc7639a70f1b1f87ba283296f3c8a8548f1e7cf38e38cea86243af5347d388a92f81a57098f2b7e172ff0950a9ce24626bec64e656cbce2fb175f7cb11d3bfff2ce537987a5bf323ee7308e6447ea609fc358f7b392233992a389c9d144de41221d3888c2a478b0addeebe277c68e6cf91a15c5d351e20e11e9a29451184536e2f328161091d18f7ef4a383ee08919e8fd92d71902f152291bbb8b865f9ef896b77a4ef53ee2bb53b4ab4793122471394a3462dd6e368e980579a91555c77e202a8e9b5e92072ac9be9f9341bab5238edaa5c6017d7d174cd94e8dba3a82e67b278d0396536de375dcfa5d17a5da9dd8235dd9d250e34343a089eb66195d22971c3cd4dbbe6c839f5a0a81f343d379dfb1a17c58aa39cf1584cd14d9d7cb418218c0efefaebaf1fd8198962e0ca2baf1cd811a9d769c7084af9f7a6a3c2b113962e18162d767ce2e8707124343624b10313af5fb76e5dddff47bc5f2a26e20ae2f57e6fda118af391d3462376aed2c624363cc51193b4d3973618c58d54fcbef295c1dba4f3dfd0dddd7d61839da7d18c4434ba4d50bdab0d0f6747ea605e6d78c8cf4a8ee4488e262e479571be83441c748a6cc5e92769e431fe1dd92b1e308816854ffabb8ba38f8d72982e761923fae97591f374202ed6f3638e39a66141513ca8172d4e5149070ed26ca0d497a40c17ef5491febfe9609c1c4deded51a39927c58bb8566aa7659d7aeaa9d5823b0e22a58362d1e2c06f3193b11ea7d1ee782cb669e9a058711dbdefbefbaa07b6239f719d98e26be3605a7affd80615f31207788b077cd3ac947286a3304fb3e252d11e775ea97750b858c81773920e20a6d9711d50d4375c375cfd1e14f5d51de9d89929ee04c4d4ac62a75eebb40646f5e2fcdf28441abd677174240a9a280e1a8d56a60b6ac5ebe3f7c4c6255e5fef886b3a225cdef18a0d441413b1014953928bb7f52a8f54c679c8b13318fff774dfed5480a4ab7517471887daf94c1ba336eafc871a0919ed8844b3fbfe36bb6f7023d32a07e7bec02d7d56722447723431399a883b48444ecaef536fd43fedf8a7836ba9b8aed4a61a47311edf470ecaeb732a122a85992b31b539e528dde521febec868f100463a75200e1a944f8fa9370a1a394fa7084441161996a3a99da36623f5c511f6d81ea503ae8d0ae274a028fafa383015dbb6744020f5f9c53b97a4c23d8af85897d32cb43493a5b85d4b0787e3205bda1ea65cc5d77befbd77d06c95f473e583d295d2292831032efdbe983913594b0731e26b9ae5d60123f54dd70df7a90745bd36c9ae923a0acd46269aed405546b82395a65c5e28479a1c4ddd1c4dd41d245a2deaa3d089c23e8a9318c58ce23c5e531c654c17898c030ec502228aee984e9cfef64a8391fa7aa388e98040f1ee11e5d7c7487d1ad14c7f4fa5ce7533e4c8f6a87cf039ada3b1cec5fa150771a338ae144e73291eac4a0780635659fc7c1ab98f834f95daad4e8bb7564d070d52f15cefee2cc54cc64181743bd5e274f928c0a34f885937712a4ebd83ccf50ea8950bf4d407140fb4a503762943ed5ed4b762d6ac599fce0becfd5168e7df5797d578887e71f6ecd9bf2d14f59f516d81624431d27e1a8d90b4ba0335dc1da9f4fb2e94234d8ee46822ee209166b4c4692ef1bae205b3e27796a7f9c67351b0470110c5471a554f53f7d3a879f1f7152f06990a9018a98fe7e39493722152bcce441aa92fdf3d220a9198bd10af8991cf7a0704daed9c7a396abfed513a87be521b054fc57efc3b9d9b5e3ee73cd6dd184d8f6bc5c4e92d716bd2bbeeba6be0a052a530529f46e553a15eef14af6226d38c812816232ba9e02e5ea4b57c01c894a97441bd6286ebcd54a934987e9f4e978bd30926c3f628ee5b9f8aedf8ccc6c3638f3d561ca55fa7d282495e8c546a57be2e767a3d3d3dd54e37a655c68e52f9f5b181285f25bbd1e8cc70af141c3b49e5f73e189f4d07ec44a51192f2d4c3cb2ac3bfef6fbd1da939c318899994394aa3786927aa7c15e0d4e235e529e99506b7952b5e5c2c767662272b8aa068c59d9d5408a473ff637a6f7a4da3d7b563eee46872e668a2ee20112383699a713c17e7dea73b3a94f3983ef3284c6204314df3af34b97857fafdc5f397e3ef8adb3996a7d4b75ad447c1950aa0e2a863bd62a551bf2247b647b1eea7752d46dd633d8b42382e42d9e8427231753d7e26d6f9588f4f3ef9e481592ae9dcf7c8646424a6e9a77531fe9dcec32f6f67caa3faf13b63fb15b368d2d4fb78acde9d5d62da7c6c1f2bb5d30862264d64257d36f5721ca784c5df140724e275e9a0c468ae7cdf8645fd85a9e08ed1fab1be605ebc5fbe2f3f304a9fffbed92a2d98a4457dba926f5ce827edf4a4db93a45b12d53bea5a2eeae3df713feb46ef3fdc2b05c76d87a2a848af4da334e9fbe2555b15f507ece0cca8b343d4ca0e54a5c9cf4dd86d82da294769aa5f14d469dd1cea8adb312d3215396944a178fba1e205f16247280a9cd8f14fd31dd34e4ff175c57bd4c78866bddf5bce67bbe54e8e26678e26e20e12319a1885761401d75e7bedc0c1a62802a238881cc514e4f2ef8962a09897a18afa18c98cf78fdcc4fb17473b1b5d0ba3de0181c847a3739c8be7d4c7df56bcb8581442f5a63ccb91ed513a3894fae098569fce2f2f1e1c2a17f5699d4ce7d4570ab7324de7d447aed2804d711d6d36fd3ebd268aedb8064b3c17070cd2f7439d5292d6ffe281bcf478e42f5dcf224e7949b7df2b9ef35f295c2caf784d804ede1ee5c5f653a9e88e6b148cd5eded623fe22b5ff9ca07c551fa615e2b03e8a4a23e3af962919276562ab5ab5cc773c51d9862071bcfa51dacd8d96ad481b77aa5e0748196b81a6a1c558e1dc4d870a40d452b17f09ac2457d714767666187684e65f8b7052affdc68ef47dcb139aa9466b0a4e2a2fcba1839889d91b81051e426462dd27a5f6f64a1bc73154576ec5045917fd55557d53d0890ae5a9faebc5f1c4189f7298e74b45beee46872e768bcee209166c7c4b626d6fdb85a7e3977c582238d44c6fb45b15cbc477df9005b141069143d0e44c4df1e07018a17062bfe6cbd5b44960ba87adbd794f574b1cd34ca99ce43bef5d65b07dd6a4f8e6c8fcaeb58baeb4814b47180b77c4786a146ea639b952e845a7cafe281b7d4d7472e5211586fa43e6526eed292f216057aca7b3a7fbf7ce1d66871ea4b1c304edbd29485c87ea57021d8e23deed305012327c583028d0eb8756851ff99bced4a9f7bfc5f475bd8c7bec3edb7df5e3c8fbebfbbbbfb4455164ce2a2be780fed34252b75d4a9e3af7734346d102ab50b970c75d06038570a4e3b3ac5298c95da154fd328e6488fce4e8162a4de8ed4588cb84cf85585db21478d0e56c5e331125f3ea738d6e9d861899d99d8414fb7df8a192cb10352294cb14def1d198bbccd9f3fbffa58ba7057bda9fb31c2190552f9ef898227edf8a4f76fb7dcc9d1e4ccd178df41a27cabba6211903293eee2d0682641abe72bb7fafae114f5a96fa8942e8e57bc709f1cc9d1502dcd1c494570bac55c714648a5749a54a5701bd2345dbebc9f56299d3b5fa99dc6556f9658bd73ea53911e7f47fceeb8ed6a79865b7c8d6d531c288803c643dd09a65e8b9cc476b4f837c5fb46915a299c86331972d4d5d5f5a574d1bc34623fd2a9f8f173a5117ad3ee61b217f5695425a650c574a9d8d98a1d90281ea21089e763c31045473a7a1a477b5391109d74f1dcabf83edd32254ddd1fee9582537151a95d0825bec6a84e2a8a1adda35b513f2e3b5263bd43d631398a753b463a8ae715a6753c463d6244a1521b814f172a8a91fa285cca99883ca511f928e263a4a5389d3f8d68540ae7d7a6dbf6147782d2ad7de2ef8a2b0bc73d85e36f89af316a529e41d04eb993a3a99923cdf6488ee4488e5a9317df738b857d9c631fb320e2c048ab57b98f8be215cfa18fd6d5d5f555d5154c81ce3f465aa2808f8b01c54e7f4ccb4d57292d5e0d380a81e2f99395da94c898aed5ec3cdb4a8b17158a96ee231cbf2f8aa1286ed291e6341d384669ec44b534a2319a298a1d37c571ac7214457af15cbee2d4c354fc962f08593c0f37462c52419f46e9d2c8466a51dca769ca51a0a7223ecd9249c57d14f5b1fe47219fa65316cf95afd4ee459c6ec555beef70bbe44e8ea65e8e34db23399223391a9e18b1cfdbee62511ec57d9c06b87af5eaea287c9a9a1fdbe8bebebeeabef85ffdd55f65975d76d96f8a3f1753eee34081ca0aa648e79fce892f16f0a9a04817dfaa34b9505ea5709b95d116f5f1589c2b96a68ea5a9665114a5e967e52bf1db896aba2334dc918d8eba08d178e728d6b99b6ebae980f3fbca57b96f746e631c0448a3f2c5161be3e201b2345d315d24a878ae7d7a7da373278b539fdb35777224479aed911c6972d45c9c635fbcd5dd08db3ae7d0c314ebfcd3f98bc59dff746e7d141a51cc544ae76f958bfa7431a318711ccd9582e3f746f11217ec8a02240e2ec4a8613c97a6044ff4c5f23a7c27aab84334739c5e3fa97394d6edb40ec7b98195da887aa3423a8dd4a7d1f498fd1223dfc5d745d11ceb74bc6fba285014d531ed3f15ede9405bf9b64095c215f8872aeadb297772647ba4d91ec9912647c32aee2fa915f7fb8753ccc7e8bcabdcc314ecfcd3c8631aa1ab142e9017a3f351d4342a5ee25cde381f3f8afb383870dd75d7551f8ffb1537baa856a5c94585d26b7a7a7a0e28aad29581e3fbf3cf3f5fe73f3e3b52d3f2d69fb70be5e8ffcf6289abd2a791f2b82f70f18240ad14f59506b7c14b570c4f57f14da3f3919dc8563ac056feb9387f3e2e209446d01b5d95bb9d722747b6479aed911c6972347cb366cdfa745edc5f9717eb8bf2b6356f7b6a057c7cdd96b72579bb2146f85551a0f3afbb83df688a71f19629e5c76304b33c2a3992e2223e871815adf73b2a1378c1bc49b2131566d47690660cf1fcaec9b0033516398a223c0e4ea5623ea6cac72de12a4dae025fa95d68aedeed1febbd3e46f1e37a16b1aea7036ba9c5fb343a80107f4fbabf772ba3e8073b7772647ba4d91ec991264780a25ed3f98fdf08c9a498e228477224477224477224479aa21ed0f96b93bdf32fef304dba1d2839922339922339922339d214f580ce5f9bcc9d7fda715a381977a0e4488ee4488ee4488ee44853d4033a7f6db277fe71ce6256e9e0db04c9911cc9911cc9911cc991264780ce5f9bca9dff27e4489323399223399223399223009dbfce1f39d2e4488e3439428ee40840e7aff3478ee40839d2e4488e34390274fe9ace5f8e3439428ee40839d2e408d0f9ebfc91234d8ee4489323e4488e0074fe3a7fe4488e90234d8ee448932340e7afe9fc912339428ee40839d2e408d0f96b3a7f39d2e408399223e4488e0074fe3a7fe448932339d2e40839922340e7afe9fc912339428e343992234d8e009dbfa6f397234d8e902339428ee4488e009dbfce1f39d2e4488e3439428ee40840e7aff3478ee40839d2e4488e34390274fe9ace1f399223e4488e90234d8e009dbfa6f397234d8e902339428ee40840e7aff3478e343992234d8ee4c8fa2b47c054b372e54a9d6efbb43d79e7bfdf5a29479a1cc9912647c8911c01b464eddab56feddcb953c7db06adafafefeff2ceff256ba51c697224479a1c21477204d09255ab565db07af5ea5fbdfdf6dbefeb800fde91dce8f857ac58f146de2eb156ca91264772649d9623e4488e005a967738337b7b7b37c614a138f7479bf0169ffb4b3a7e39d2e4488ee4488e90233902000000000000000000000000000000000000000000000000000000000000000000008031f57f0116a1ea91bc6b7b3d0000000049454e44ae426082, '1'), ('57502', '7', 'source', null, 0x7b227265736f757263654964223a223537353031222c2270726f70657274696573223a7b2270726f636573735f6964223a2273616c617279222c226e616d65223a22e6b581e7a88be5aea1e689b9e6b58be8af95e6b581e7a88b222c22646f63756d656e746174696f6e223a22222c2270726f636573735f617574686f72223a22626f6f74646f222c2270726f636573735f76657273696f6e223a22222c2270726f636573735f6e616d657370616365223a22687474703a2f2f7777772e61637469766974692e6f72672f74657374222c22657865637574696f6e6c697374656e657273223a227b5c22657865637574696f6e4c697374656e6572735c223a5c225b5d5c227d222c226576656e746c697374656e657273223a227b5c226576656e744c697374656e6572735c223a5c225b5d5c227d222c227369676e616c646566696e6974696f6e73223a225c225b5d5c22222c226d657373616765646566696e6974696f6e73223a225c225b5d5c22222c226d65737361676573223a5b5d7d2c227374656e63696c223a7b226964223a2242504d4e4469616772616d227d2c226368696c64536861706573223a5b7b227265736f757263654964223a227374617274222c2270726f70657274696573223a7b226f766572726964656964223a227374617274222c226e616d65223a22e590afe58aa8e5aea1e689b9222c22646f63756d656e746174696f6e223a22222c22657865637574696f6e6c697374656e657273223a22222c22696e69746961746f72223a226170706c79222c22666f726d6b6579646566696e6974696f6e223a222f6163742f73616c6172792f666f726d222c22666f726d70726f70657274696573223a22227d2c227374656e63696c223a7b226964223a2253746172744e6f6e654576656e74227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d33364535304338422d364337432d343936382d423032442d454241413432354246344245227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a36302c2279223a3237307d2c2275707065724c656674223a7b2278223a33302c2279223a3234307d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a22656e64222c2270726f70657274696573223a7b226f766572726964656964223a22656e64222c226e616d65223a22e7bb93e69d9fe5aea1e689b9222c22646f63756d656e746174696f6e223a22222c22657865637574696f6e6c697374656e657273223a22227d2c227374656e63696c223a7b226964223a22456e644e6f6e654576656e74227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a313030332c2279223a3338347d2c2275707065724c656674223a7b2278223a3937352c2279223a3335367d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a226d6f64696679222c2270726f70657274696573223a7b226f766572726964656964223a226d6f64696679222c226e616d65223a22e59198e5b7a5e896aae985ace6a1a3e7baa7e4bfaee694b9222c22646f63756d656e746174696f6e223a22222c226173796e6368726f6e6f7573646566696e6974696f6e223a66616c73652c226578636c7573697665646566696e6974696f6e223a747275652c22657865637574696f6e6c697374656e657273223a7b22657865637574696f6e4c697374656e657273223a5b5d7d2c226d756c7469696e7374616e63655f74797065223a224e6f6e65222c226d756c7469696e7374616e63655f63617264696e616c697479223a22222c226d756c7469696e7374616e63655f636f6c6c656374696f6e223a22222c226d756c7469696e7374616e63655f7661726961626c65223a22222c226d756c7469696e7374616e63655f636f6e646974696f6e223a22222c226973666f72636f6d70656e736174696f6e223a2266616c7365222c22757365727461736b61737369676e6d656e74223a7b2261737369676e6d656e74223a7b2261737369676e6565223a22247b6170706c797d227d7d2c22666f726d6b6579646566696e6974696f6e223a22222c2264756564617465646566696e6974696f6e223a22222c227072696f72697479646566696e6974696f6e223a22222c22666f726d70726f70657274696573223a22222c227461736b6c697374656e657273223a7b227461736b4c697374656e657273223a5b5d7d7d2c227374656e63696c223a7b226964223a22557365725461736b227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d31363344424336302d444243392d343338422d393731412d363737333846423737313541227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3331312c2279223a3139337d2c2275707065724c656674223a7b2278223a3230392c2279223a3133357d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a226175646974222c2270726f70657274696573223a7b226f766572726964656964223a226175646974222c226e616d65223a22e896aae985ace4b8bbe7aea1e5889de5aea1222c22646f63756d656e746174696f6e223a22222c226173796e6368726f6e6f7573646566696e6974696f6e223a66616c73652c226578636c7573697665646566696e6974696f6e223a747275652c22657865637574696f6e6c697374656e657273223a7b22657865637574696f6e4c697374656e657273223a5b5d7d2c226d756c7469696e7374616e63655f74797065223a224e6f6e65222c226d756c7469696e7374616e63655f63617264696e616c697479223a22222c226d756c7469696e7374616e63655f636f6c6c656374696f6e223a22222c226d756c7469696e7374616e63655f7661726961626c65223a22222c226d756c7469696e7374616e63655f636f6e646974696f6e223a22222c226973666f72636f6d70656e736174696f6e223a2266616c7365222c22757365727461736b61737369676e6d656e74223a7b2261737369676e6d656e74223a7b2261737369676e6565223a2261646d696e227d7d2c22666f726d6b6579646566696e6974696f6e223a22222c2264756564617465646566696e6974696f6e223a22222c227072696f72697479646566696e6974696f6e223a22222c22666f726d70726f70657274696573223a22222c227461736b6c697374656e657273223a7b227461736b4c697374656e657273223a5b5d7d7d2c227374656e63696c223a7b226964223a22557365725461736b227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d32414237433031412d353045452d344141432d384338462d463645313933354233444137227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3230312c2279223a3238327d2c2275707065724c656674223a7b2278223a3130352c2279223a3232357d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a227369642d43323842423546362d303133442d343537302d423433322d363142333830433146343646222c2270726f70657274696573223a7b226f766572726964656964223a227369642d43323842423546362d303133442d343537302d423433322d363142333830433146343646222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c226173796e6368726f6e6f7573646566696e6974696f6e223a2266616c7365222c226578636c7573697665646566696e6974696f6e223a2266616c7365222c2273657175656e6365666c6f776f72646572223a22227d2c227374656e63696c223a7b226964223a224578636c757369766547617465776179227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d35333235383530322d343345452d344445382d423141342d444244313139323242384146227d2c7b227265736f757263654964223a227369642d37323235384134312d323033452d343238432d423731442d434133353036323532443733227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3238302c2279223a3238307d2c2275707065724c656674223a7b2278223a3234302c2279223a3234307d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a22617564697432222c2270726f70657274696573223a7b226f766572726964656964223a22617564697432222c226e616d65223a22e99b86e59ba2e4babae58a9be8b584e6ba90e983a8e983a8e995bfe5aea1e6a0b8222c22646f63756d656e746174696f6e223a22222c226173796e6368726f6e6f7573646566696e6974696f6e223a66616c73652c226578636c7573697665646566696e6974696f6e223a747275652c22657865637574696f6e6c697374656e657273223a7b22657865637574696f6e4c697374656e657273223a5b5d7d2c226d756c7469696e7374616e63655f74797065223a224e6f6e65222c226d756c7469696e7374616e63655f63617264696e616c697479223a22222c226d756c7469696e7374616e63655f636f6c6c656374696f6e223a22222c226d756c7469696e7374616e63655f7661726961626c65223a22222c226d756c7469696e7374616e63655f636f6e646974696f6e223a22222c226973666f72636f6d70656e736174696f6e223a2266616c7365222c22757365727461736b61737369676e6d656e74223a7b2261737369676e6d656e74223a7b2261737369676e6565223a2261646d696e227d7d2c22666f726d6b6579646566696e6974696f6e223a22222c2264756564617465646566696e6974696f6e223a22222c227072696f72697479646566696e6974696f6e223a22222c22666f726d70726f70657274696573223a22222c227461736b6c697374656e657273223a7b227461736b4c697374656e657273223a5b5d7d7d2c227374656e63696c223a7b226964223a22557365725461736b227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d45463246353142422d314439392d344630422d414346322d423643313330304137443242227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3331302c2279223a3431307d2c2275707065724c656674223a7b2278223a3231302c2279223a3333307d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a227369642d45443436464534312d413046442d343936442d383644432d324339374146353733354630222c2270726f70657274696573223a7b226f766572726964656964223a227369642d45443436464534312d413046442d343936442d383644432d324339374146353733354630222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c226173796e6368726f6e6f7573646566696e6974696f6e223a2266616c7365222c226578636c7573697665646566696e6974696f6e223a2266616c7365222c2273657175656e6365666c6f776f72646572223a22227d2c227374656e63696c223a7b226964223a224578636c757369766547617465776179227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d41373538393038342d343632332d344645412d413737342d303041373044444331443230227d2c7b227265736f757263654964223a227369642d46413631383633362d333730382d344430432d383531342d323941344242384243393236227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3338352c2279223a3339307d2c2275707065724c656674223a7b2278223a3334352c2279223a3335307d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a227369642d45463246353142422d314439392d344630422d414346322d423643313330304137443242222c2270726f70657274696573223a7b226f766572726964656964223a227369642d45463246353142422d314439392d344630422d414346322d423643313330304137443242222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d45443436464534312d413046442d343936442d383644432d324339374146353733354630227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3334352e313332383132352c2279223a3337307d2c2275707065724c656674223a7b2278223a3331302e32313837352c2279223a3337307d7d2c22646f636b657273223a5b7b2278223a35302c2279223a34307d2c7b2278223a32302c2279223a32307d5d2c22746172676574223a7b227265736f757263654964223a227369642d45443436464534312d413046442d343936442d383644432d324339374146353733354630227d7d2c7b227265736f757263654964223a22617564697433222c2270726f70657274696573223a7b226f766572726964656964223a22617564697433222c226e616d65223a22e99b86e59ba2e4babae58a9be8b584e6ba90e983a8e58886e7aea1e9a286e5afbce5aea1e6a0b8222c22646f63756d656e746174696f6e223a22222c226173796e6368726f6e6f7573646566696e6974696f6e223a66616c73652c226578636c7573697665646566696e6974696f6e223a747275652c22657865637574696f6e6c697374656e657273223a7b22657865637574696f6e4c697374656e657273223a5b5d7d2c226d756c7469696e7374616e63655f74797065223a224e6f6e65222c226d756c7469696e7374616e63655f63617264696e616c697479223a22222c226d756c7469696e7374616e63655f636f6c6c656374696f6e223a22222c226d756c7469696e7374616e63655f7661726961626c65223a22222c226d756c7469696e7374616e63655f636f6e646974696f6e223a22222c226973666f72636f6d70656e736174696f6e223a2266616c7365222c22757365727461736b61737369676e6d656e74223a7b2261737369676e6d656e74223a7b2261737369676e6565223a2261646d696e227d7d2c22666f726d6b6579646566696e6974696f6e223a22222c2264756564617465646566696e6974696f6e223a22222c227072696f72697479646566696e6974696f6e223a22222c22666f726d70726f70657274696573223a22222c227461736b6c697374656e657273223a7b227461736b4c697374656e657273223a5b5d7d7d2c227374656e63696c223a7b226964223a22557365725461736b227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d33444243443636312d353732302d343438302d383135362d373438424530323735464546227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3532302c2279223a3431307d2c2275707065724c656674223a7b2278223a3432302c2279223a3333307d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a227369642d46453438354232442d394132332d343233362d424430442d443738384341364533304534222c2270726f70657274696573223a7b226f766572726964656964223a227369642d46453438354232442d394132332d343233362d424430442d443738384341364533304534222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c226173796e6368726f6e6f7573646566696e6974696f6e223a2266616c7365222c226578636c7573697665646566696e6974696f6e223a2266616c7365222c2273657175656e6365666c6f776f72646572223a22227d2c227374656e63696c223a7b226964223a224578636c757369766547617465776179227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d44343443414434332d303237312d343932302d413532342d394238353333453532353530227d2c7b227265736f757263654964223a227369642d31353235424646342d334539442d344438412d424638302d314636334146453136323839227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3539352c2279223a3339307d2c2275707065724c656674223a7b2278223a3535352c2279223a3335307d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a227369642d33444243443636312d353732302d343438302d383135362d373438424530323735464546222c2270726f70657274696573223a7b226f766572726964656964223a227369642d33444243443636312d353732302d343438302d383135362d373438424530323735464546222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d46453438354232442d394132332d343233362d424430442d443738384341364533304534227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3535352e313332383132352c2279223a3337307d2c2275707065724c656674223a7b2278223a3532302e32313837352c2279223a3337307d7d2c22646f636b657273223a5b7b2278223a35302c2279223a34307d2c7b2278223a32302c2279223a32307d5d2c22746172676574223a7b227265736f757263654964223a227369642d46453438354232442d394132332d343233362d424430442d443738384341364533304534227d7d2c7b227265736f757263654964223a22617564697434222c2270726f70657274696573223a7b226f766572726964656964223a22617564697434222c226e616d65223a22e99b86e59ba2e680bbe7bb8fe79086e5aea1e689b9222c22646f63756d656e746174696f6e223a22222c226173796e6368726f6e6f7573646566696e6974696f6e223a66616c73652c226578636c7573697665646566696e6974696f6e223a747275652c22657865637574696f6e6c697374656e657273223a7b22657865637574696f6e4c697374656e657273223a5b5d7d2c226d756c7469696e7374616e63655f74797065223a224e6f6e65222c226d756c7469696e7374616e63655f63617264696e616c697479223a22222c226d756c7469696e7374616e63655f636f6c6c656374696f6e223a22222c226d756c7469696e7374616e63655f7661726961626c65223a22222c226d756c7469696e7374616e63655f636f6e646974696f6e223a22222c226973666f72636f6d70656e736174696f6e223a2266616c7365222c22757365727461736b61737369676e6d656e74223a7b2261737369676e6d656e74223a7b2261737369676e6565223a2261646d696e227d7d2c22666f726d6b6579646566696e6974696f6e223a22222c2264756564617465646566696e6974696f6e223a22222c227072696f72697479646566696e6974696f6e223a22222c22666f726d70726f70657274696573223a22222c227461736b6c697374656e657273223a7b227461736b4c697374656e657273223a5b5d7d7d2c227374656e63696c223a7b226964223a22557365725461736b227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d30324442324144392d313333322d343139382d414338442d323241333531363944313543227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3733302c2279223a3431307d2c2275707065724c656674223a7b2278223a3633302c2279223a3333307d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a227369642d33463533423642442d463846332d343936422d414330382d353036333042443131343737222c2270726f70657274696573223a7b226f766572726964656964223a227369642d33463533423642442d463846332d343936422d414330382d353036333042443131343737222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c226173796e6368726f6e6f7573646566696e6974696f6e223a2266616c7365222c226578636c7573697665646566696e6974696f6e223a2266616c7365222c2273657175656e6365666c6f776f72646572223a22227d2c227374656e63696c223a7b226964223a224578636c757369766547617465776179227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d37443732333139302d313433322d343131442d413441342d373734323235453534434439227d2c7b227265736f757263654964223a227369642d33354343384336432d313036372d343339382d393931432d434346393535313135393635227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3830352c2279223a3339307d2c2275707065724c656674223a7b2278223a3736352c2279223a3335307d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a226170706c795f656e64222c2270726f70657274696573223a7b226f766572726964656964223a226170706c795f656e64222c226e616d65223a22e896aae985ace6a1a3e7baa7e58591e78eb0222c22646f63756d656e746174696f6e223a22222c226173796e6368726f6e6f7573646566696e6974696f6e223a66616c73652c226578636c7573697665646566696e6974696f6e223a747275652c22657865637574696f6e6c697374656e657273223a7b22657865637574696f6e4c697374656e657273223a5b5d7d2c226d756c7469696e7374616e63655f74797065223a224e6f6e65222c226d756c7469696e7374616e63655f63617264696e616c697479223a22222c226d756c7469696e7374616e63655f636f6c6c656374696f6e223a22222c226d756c7469696e7374616e63655f7661726961626c65223a22222c226d756c7469696e7374616e63655f636f6e646974696f6e223a22222c226973666f72636f6d70656e736174696f6e223a2266616c7365222c22757365727461736b61737369676e6d656e74223a7b2261737369676e6d656e74223a7b2261737369676e6565223a2261646d696e227d7d2c22666f726d6b6579646566696e6974696f6e223a22222c2264756564617465646566696e6974696f6e223a22222c227072696f72697479646566696e6974696f6e223a22222c22666f726d70726f70657274696573223a22222c227461736b6c697374656e657273223a7b227461736b4c697374656e657273223a5b5d7d7d2c227374656e63696c223a7b226964223a22557365725461736b227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d42444230414142322d374535302d344433352d383045452d434530424543444439463537227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3934302c2279223a3431307d2c2275707065724c656674223a7b2278223a3834302c2279223a3333307d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a227369642d30324442324144392d313333322d343139382d414338442d323241333531363944313543222c2270726f70657274696573223a7b226f766572726964656964223a227369642d30324442324144392d313333322d343139382d414338442d323241333531363944313543222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d33463533423642442d463846332d343936422d414330382d353036333042443131343737227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3736352e313332383132352c2279223a3337307d2c2275707065724c656674223a7b2278223a3733302e32313837352c2279223a3337307d7d2c22646f636b657273223a5b7b2278223a35302c2279223a34307d2c7b2278223a32302c2279223a32307d5d2c22746172676574223a7b227265736f757263654964223a227369642d33463533423642442d463846332d343936422d414330382d353036333042443131343737227d7d2c7b227265736f757263654964223a227369642d32414237433031412d353045452d344141432d384338462d463645313933354233444137222c2270726f70657274696573223a7b226f766572726964656964223a227369642d32414237433031412d353045452d344141432d384338462d463645313933354233444137222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d43323842423546362d303133442d343537302d423433322d363142333830433146343646227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3234312e34343731353235343831353839332c2279223a3235382e383732393537383635303735317d2c2275707065724c656674223a7b2278223a3230312e36343635393734353138343130372c2279223a3235362e343535313637313334393234397d7d2c22646f636b657273223a5b7b2278223a34382c2279223a32382e357d2c7b2278223a32302c2279223a32307d5d2c22746172676574223a7b227265736f757263654964223a227369642d43323842423546362d303133442d343537302d423433322d363142333830433146343646227d7d2c7b227265736f757263654964223a227369642d33364535304338422d364337432d343936382d423032442d454241413432354246344245222c2270726f70657274696573223a7b226f766572726964656964223a227369642d33364535304338422d364337432d343936382d423032442d454241413432354246344245222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a226175646974227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3130342e363332383132352c2279223a3235357d2c2275707065724c656674223a7b2278223a36302e303632352c2279223a3235332e357d7d2c22646f636b657273223a5b7b2278223a31352c2279223a31357d2c7b2278223a38322e352c2279223a3235357d2c7b2278223a38322e352c2279223a3235332e357d2c7b2278223a34382c2279223a32382e357d5d2c22746172676574223a7b227265736f757263654964223a226175646974227d7d2c7b227265736f757263654964223a227369642d37443732333139302d313433322d343131442d413441342d373734323235453534434439222c2270726f70657274696573223a7b226f766572726964656964223a227369642d37443732333139302d313433322d343131442d413441342d373734323235453534434439222c226e616d65223a22e698af222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22247b706173733d3d317d222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a226170706c795f656e64227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3833392e37383132352c2279223a3337307d2c2275707065724c656674223a7b2278223a3830342e383637313837352c2279223a3337307d7d2c22646f636b657273223a5b7b2278223a32302c2279223a32307d2c7b2278223a35302c2279223a34307d5d2c22746172676574223a7b227265736f757263654964223a226170706c795f656e64227d7d2c7b227265736f757263654964223a227369642d44343443414434332d303237312d343932302d413532342d394238353333453532353530222c2270726f70657274696573223a7b226f766572726964656964223a227369642d44343443414434332d303237312d343932302d413532342d394238353333453532353530222c226e616d65223a22e698af222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22247b706173733d3d317d222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a22617564697434227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3632392e37383132352c2279223a3337307d2c2275707065724c656674223a7b2278223a3539342e383637313837352c2279223a3337307d7d2c22646f636b657273223a5b7b2278223a32302c2279223a32307d2c7b2278223a35302c2279223a34307d5d2c22746172676574223a7b227265736f757263654964223a22617564697434227d7d2c7b227265736f757263654964223a227369642d35333235383530322d343345452d344445382d423141342d444244313139323242384146222c2270726f70657274696573223a7b226f766572726964656964223a227369642d35333235383530322d343345452d344445382d423141342d444244313139323242384146222c226e616d65223a22e590a6222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22247b706173733d3d307d222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a226d6f64696679227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3236302c2279223a3233392e357d2c2275707065724c656674223a7b2278223a3236302c2279223a3139332e357d7d2c22646f636b657273223a5b7b2278223a32302c2279223a32307d2c7b2278223a35312c2279223a32397d5d2c22746172676574223a7b227265736f757263654964223a226d6f64696679227d7d2c7b227265736f757263654964223a227369642d35464544303244362d433338382d343843362d383730452d303937444232313331454130222c2270726f70657274696573223a7b226f766572726964656964223a227369642d35464544303244362d433338382d343843362d383730452d303937444232313331454130222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c226173796e6368726f6e6f7573646566696e6974696f6e223a2266616c7365222c226578636c7573697665646566696e6974696f6e223a2266616c7365222c2273657175656e6365666c6f776f72646572223a22227d2c227374656e63696c223a7b226964223a224578636c757369766547617465776179227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d38343438454634412d423632452d343839392d414243322d304532444232414536383338227d2c7b227265736f757263654964223a227369642d34344146423943312d343035372d344334382d423146322d314543383937413532434237227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3238302c2279223a38357d2c2275707065724c656674223a7b2278223a3234302c2279223a34357d7d2c22646f636b657273223a5b5d7d2c7b227265736f757263654964223a227369642d31363344424336302d444243392d343338422d393731412d363737333846423737313541222c2270726f70657274696573223a7b226f766572726964656964223a227369642d31363344424336302d444243392d343338422d393731412d363737333846423737313541222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a227369642d35464544303244362d433338382d343843362d383730452d303937444232313331454130227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3236302c2279223a3133342e333832383132357d2c2275707065724c656674223a7b2278223a3236302c2279223a38342e353632357d7d2c22646f636b657273223a5b7b2278223a35312c2279223a32397d2c7b2278223a32302c2279223a32307d5d2c22746172676574223a7b227265736f757263654964223a227369642d35464544303244362d433338382d343843362d383730452d303937444232313331454130227d7d2c7b227265736f757263654964223a227369642d37323235384134312d323033452d343238432d423731442d434133353036323532443733222c2270726f70657274696573223a7b226f766572726964656964223a227369642d37323235384134312d323033452d343238432d423731442d434133353036323532443733222c226e616d65223a22e698af222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22247b706173733d3d317d222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a22617564697432227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3236302c2279223a3332392e34363837357d2c2275707065724c656674223a7b2278223a3236302c2279223a3237392e39303632357d7d2c22646f636b657273223a5b7b2278223a32302c2279223a32307d2c7b2278223a35302c2279223a34307d5d2c22746172676574223a7b227265736f757263654964223a22617564697432227d7d2c7b227265736f757263654964223a227369642d38343438454634412d423632452d343839392d414243322d304532444232414536383338222c2270726f70657274696573223a7b226f766572726964656964223a227369642d38343438454634412d423632452d343839392d414243322d304532444232414536383338222c226e616d65223a22e9878de696b0e794b3e8afb7222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22247b706173733d3d317d222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a226175646974227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3233392e373733343337352c2279223a3232342e35313935333132357d2c2275707065724c656674223a7b2278223a3135332c2279223a36357d7d2c22646f636b657273223a5b7b2278223a32302c2279223a32307d2c7b2278223a3135332c2279223a36357d2c7b2278223a34382c2279223a32382e357d5d2c22746172676574223a7b227265736f757263654964223a226175646974227d7d2c7b227265736f757263654964223a227369642d41373538393038342d343632332d344645412d413737342d303041373044444331443230222c2270726f70657274696573223a7b226f766572726964656964223a227369642d41373538393038342d343632332d344645412d413737342d303041373044444331443230222c226e616d65223a22e698af222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22247b706173733d3d317d222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a22617564697433227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3431392e37383132352c2279223a3337307d2c2275707065724c656674223a7b2278223a3338342e383637313837352c2279223a3337307d7d2c22646f636b657273223a5b7b2278223a32302c2279223a32307d2c7b2278223a35302c2279223a34307d5d2c22746172676574223a7b227265736f757263654964223a22617564697433227d7d2c7b227265736f757263654964223a227369642d46413631383633362d333730382d344430432d383531342d323941344242384243393236222c2270726f70657274696573223a7b226f766572726964656964223a227369642d46413631383633362d333730382d344430432d383531342d323941344242384243393236222c226e616d65223a22e590a6222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22247b706173733d3d307d222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a226d6f64696679227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3336352c2279223a3334392e363837357d2c2275707065724c656674223a7b2278223a3331312e3835393337352c2279223a3136347d7d2c22646f636b657273223a5b7b2278223a32302c2279223a32307d2c7b2278223a3336352c2279223a3136347d2c7b2278223a35312c2279223a32397d5d2c22746172676574223a7b227265736f757263654964223a226d6f64696679227d7d2c7b227265736f757263654964223a227369642d31353235424646342d334539442d344438412d424638302d314636334146453136323839222c2270726f70657274696573223a7b226f766572726964656964223a227369642d31353235424646342d334539442d344438412d424638302d314636334146453136323839222c226e616d65223a22e590a6222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22247b706173733d3d307d222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a226d6f64696679227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3537352c2279223a3334392e363837357d2c2275707065724c656674223a7b2278223a3331312e34343932313837352c2279223a3136347d7d2c22646f636b657273223a5b7b2278223a32302c2279223a32307d2c7b2278223a3537352c2279223a3136347d2c7b2278223a35312c2279223a32397d5d2c22746172676574223a7b227265736f757263654964223a226d6f64696679227d7d2c7b227265736f757263654964223a227369642d33354343384336432d313036372d343339382d393931432d434346393535313135393635222c2270726f70657274696573223a7b226f766572726964656964223a227369642d33354343384336432d313036372d343339382d393931432d434346393535313135393635222c226e616d65223a22e590a6222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22247b706173733d3d307d222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a226d6f64696679227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3738352c2279223a3334392e363837357d2c2275707065724c656674223a7b2278223a3331312e3234343134303632352c2279223a3136347d7d2c22646f636b657273223a5b7b2278223a32302c2279223a32307d2c7b2278223a3738352c2279223a3136347d2c7b2278223a35312c2279223a32397d5d2c22746172676574223a7b227265736f757263654964223a226d6f64696679227d7d2c7b227265736f757263654964223a227369642d42444230414142322d374535302d344433352d383045452d434530424543444439463537222c2270726f70657274696573223a7b226f766572726964656964223a227369642d42444230414142322d374535302d344433352d383045452d434530424543444439463537222c226e616d65223a22222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a22656e64227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3937342e3037383132352c2279223a3337307d2c2275707065724c656674223a7b2278223a3934302e352c2279223a3337307d7d2c22646f636b657273223a5b7b2278223a35302c2279223a34307d2c7b2278223a31342c2279223a31347d5d2c22746172676574223a7b227265736f757263654964223a22656e64227d7d2c7b227265736f757263654964223a227369642d34344146423943312d343035372d344334382d423146322d314543383937413532434237222c2270726f70657274696573223a7b226f766572726964656964223a227369642d34344146423943312d343035372d344334382d423146322d314543383937413532434237222c226e616d65223a22e99480e6af81222c22646f63756d656e746174696f6e223a22222c22636f6e646974696f6e73657175656e6365666c6f77223a22247b706173733d3d307d222c22657865637574696f6e6c697374656e657273223a22222c2264656661756c74666c6f77223a2266616c7365227d2c227374656e63696c223a7b226964223a2253657175656e6365466c6f77227d2c226368696c64536861706573223a5b5d2c226f7574676f696e67223a5b7b227265736f757263654964223a22656e64227d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a3938392c2279223a3335352e38393435333132357d2c2275707065724c656674223a7b2278223a3238302e323231363739363837352c2279223a36357d7d2c22646f636b657273223a5b7b2278223a32302c2279223a32307d2c7b2278223a3938392c2279223a36357d2c7b2278223a31342c2279223a31347d5d2c22746172676574223a7b227265736f757263654964223a22656e64227d7d5d2c22626f756e6473223a7b226c6f7765725269676874223a7b2278223a313230302c2279223a313035307d2c2275707065724c656674223a7b2278223a302c2279223a307d7d2c227374656e63696c736574223a7b2275726c223a227374656e63696c736574732f62706d6e322e302f62706d6e322e302e6a736f6e222c226e616d657370616365223a22687474703a2f2f62336d6e2e6f72672f7374656e63696c7365742f62706d6e322e3023227d2c227373657874656e73696f6e73223a5b5d7d, null);
INSERT INTO `act_ge_bytearray` VALUES ('62501', '2', 'source-extra', null, 0x89504e470d0a1a0a0000000d494844520000041d000001cc0806000000995fd0b3000000206348524d00007a26000080840000fa00000080e8000075300000ea6000003a98000017709cba513c0000000467414d410000b18e7cfb5193000000017352474200aece1ce900000006624b474400ff00ff00ffa0bda793000000097048597300000ec400000ec401952b0e1b000020004944415478daecdd097c14f5fdfff1ef6c0ec21140ee5b142b9e4015cff2576c5114b5a088248242d14aada0a062ad163156d11f872048bd31a898702862ad2222a052454408970a54081148909084908b1c3bffef673213274b12726db2495ecfc7e3cbec31bb3bfbddfd867cdff97ebfa3140000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001020468f1edd925a00000000505d3c5401003179f2e491393939a9515151a3a80d00000000d521882a00f0f8e38f47eedfbfffadabafbeda888b8bfbe3a0418312befcf2cb386a060000004055103aa0a10ad5e50fba8cd165872e993ef7cb28a0c1bafc58c263c374394397e4529efb325d2ed6e58752eeef686f737d6e9fa1cbca9aae884993260d4d4c4c7c67fcf8f141d75e7badeadebdbbb17af5ea1bfbf7efffbff5ebd76faba1c3f89d2e19bae4f8dc76be2ebb4bd8bfb32e7d744970ddd656972cbb7e33f88a03000000840e404d9120e01c5dbae9324e974b7539a0cb325dd27429f009242474b85797cf7419aecb36fb71ed7489b4f72f2d54e8a54b6355186694443ad6efebf2b62eff4f97f374f98d2eb7eaf28b2e67eb72a72e9ffabb526484435252528c040e175c7081755b870e1dd469a79de659b366cd90abaebaaaa68287b9ba7cac4bb62e37da9f494ffb67d411fbfe0fec7d87e9d24397445d7eabcb78fbb1cbed7de7e8f2065f7900000080d001a809d2b13f45174397105dbada9ddb43aaf02fe6b7eb72892eebecfdafd265a42e9fe832ca0e20f6e8325a9769baac29217058688709121e5c64bf46a87dfd25fbb99cd1145e5d9ae8f29d1d32c873c95ff307eaf2ac1d6c2cb0f7f31b59bb21212161c1b871e33c4ee0e068dfbebd153cac5dbb76c8ef7ef7bb6ddf7efbed8f7e3c94e6aa705449922e77e912a30a0397b5f6fd97ebf2bc2a1cc520aed1e52d5d7eb6ebed7a5d3ed2e5f7aa70b4487f5518ea00000000207400fc2ec1eef06f5785d3255adb9d55090264c4c217f66587040c7fd4e53d5538bc7f9afdf89bcae8cc0eb3030379dea6baa4d8fbcaf5ebec10c16da72a9c5e116c3f6f777b3f09211ae992aefc3845400287f8f8f8f9f7df7fbfe7b7bffd6d89fbc888871e3d7a783efffcf39b7bf7eebd75cb962d3bfd743832aa4346326cd4e54b55382265912eeded9f51eb55e1e8915df6fe1232484a22a1513f5538eae17faa30e491e7b8439755aa701a4c0e5f7f00000080d001f0b7ab7519aa0a473ac87a0b6d54e11408090bbcae0ead8c5090e1fda9aa70f4838c88905e793bfbfa377687f73ebb839b6d3feeafaa708d8792463a0c74850eb21684fce55ea656c87400f90b7f9a7d9f84153fd997ffa4cb06d7f35767e030223e3e3e5a0287debd7b97b9af8c78e8d1a347d0575f7d75739f3e7d366fd9b26577351f8ec7aeef0beccfe47a3b483868d74b867dfbad767d0939e899aa30d8912064902ee1babcac8ba90a474cc8672cd32f8ef2d5070000006a0fa7cc444321c142b01d0484b82e07fb744c65c8be4c95785d158e3e90a911afa8c2e1fb32da619fdda17d4015ae1fe0f8c5de47cab7ba6c765d4f72ed277f91ff50154ea948b4c388eef67d2b5d9dea293ecf5f2d264c983064efdebdd6948a93050e8ef3cf3f5f3df4d043a15eaf77596464e4b5d57c48a7eb3259970e76a8f07ff6edcdec2021dcbe9ce9f373eb54573962d7e7ed76002121d199f6670500000080d001a811dfd921800402dfd897b7a8c2e90c6ed7d89d570903a4931d65778efd4516b95ce52a32bd20b5ba5f444638a4a5a52d752f1a595e123c4c9a342924383878d9f0e1c36fa8c6c33aa60aa75774b5ebfa31fbf695ead7d0c6f78c1eafd8418314993e21d366649d8da3f6fe5d74f9175f7700000080d001a829d2416da77efd4bf825f665596072bfcfbeabed8e7fbc5d5e50852319e2cb78fe4ef6f349b9c87e0de77abb32da9f9cf631dc3e1ea79c52dd6f7ef2e4c923e3e3e3dfac4ce0e00e1e1e7cf0c1b0d0d0d025d5183cc8ba0c32aa444698acd0e59ff6edd7b8eaef1a9fc774b1b7329d4246407c6c5f6f6dd7bd8c6a39c0571e0000002074006a824ca1e86087093bec90618f7d59fe8a7ebbcffe724accefeccb3fda9d6259ecf1a3325ee33655faf48aab4bd85fd66f906905dbede30b7795e0ea0e1cf6efdfbf40d670a86ce0e090291993264daaeee0c1fdf3a88f7db9ac910ef299c85a0ff9f6564ead29418d2cdc2967bd7886af3c00000040e800d414e99c2e5185eb29c83cffc376d96777606548ffefec7d43edf25f57fbb857976eaa704a86685bc26b94f597f5924e7d79962ed1f6b11d7175b0a51caaae372e532a9cc0a1bc6b389c8c3dd5222c2424647135aef12075fe9cfa75414fb7a6aecb12c8c86b4eb0af4b40b4db7ebcac8321e19084445df9da03000000b52f982a403dd7da0e14f25db735b33ba9835c9dda2b55e1c28ec7ec4eabacb3d05d159ed6f2525da6bb1e7fde495ed3a34e1ee8c95ff4b37c6e9353444e5425871a15e62c1a397efcf8a2c0212d2d4ddd73cf3d27ec3b67ce1cd5b6edaf2f9b9595a5eebcf3ce13f69b376f9e6ad5aa95153c3cfcf0c38da74d9bf66e6464e4d098989815553c5c0985d6da75e2757d5e32cde54557fd4bbdca141459b361b6fd390ed0a5852a3ca38890d0669e2ef246996601000000d422832a004e1a20f88e5408b5c388d29cec7e5fc1aa7828526532c2c10e1c4e58c3e18b2fbe500b162cb08205eb0d7a3ceaacb3ce92691845fbcc9e3d5b6ddab449e5e5e559d74f39e51475fdf5d75bc56dcb962d6afaf4e999f9f9f9118b162dfad08f755e1dfb02000000a8614154015026b384db0a4ef298820abe46b5769aa3a2a246c5c7c74797b668e4a9a79eaabefdf65b959a5a78820cd33455464686eadcb9b3ead4a993dab973a75ab66c993a7efcb8757f7070b0350a62ecd8b15640e1d6a1430775c61967a8afbffefae673ce3967eb8e1d3b76f9a9ceab635f00000000840e002acb0e1ce6cb1a0ebffded6f4bddef9c73ce515f7ef965d14886fcfc7cf5fdf7dfab2bafbc524d9d3a55a5a7a717eddbac5933a59f4fb56eddbac4e76adfbe7d90133c9c77de799bb66fdffe3f3e090000000082d001a8271e7ffcf1c8848484722d1a2941426e6eae8a8f8fb70207e1f57a555c5c9c4a4e4eb62e8bf0f07075f9e597ababaebaaacce793e0a1478f1e055f7ffdf59073ce396747358d780000000050c7113a00f5c0a4499386262626be23532aca1ae1e026eb387cf6d9672a3b3bdbba2e41838c702828f8757648d3a64dd5c48913554848c8499faf43870e21a79d765ac1faf5eb65aac536820700000000840e401d27231c9cc0a1a4351c4a23eb33f4e8d1c35adfc19966e1d6b2654beb0c16b206447975ecd831f48c33cec8fbfaebaf87123c00000000e0ec15f0ab888888ee7a339a9af08f4e9d3aa5a5a6a6ce1c376e9ca7228183dbf3cf3faf366cd85034a542482021eb3e3cf6d863957aceb8b8b89469d3a6c9593c969ba6c91a0f00000068e8a2636363e31be21b0fe6b3879f8dd6650ad5e01f070f1e54d75d779daa6ce020468e1ca9bef9e69b62b7c9192d6ebae9a64a3f679f3e7d5a75eedc397dfffefd23f89400000000cb130df14d133aa026455105d5ab5bb76ec7d6ae5d3bad77efde275d3cb234efbcf38e320cc30a1a1c32d261f9f2e5d66887cad8bc79f3a103070e34d5cfbb90910e00000068c01afc1f60091d5053a26263639fa01aaadfa38f3efaf3ac59b362eebbefbe0a4fb1d8b973a7daba756bb1a915421693dcb76f9fdab871a3eadbb76f859e530287e9d3a737d6cf19b968d1a20ff984000000d050454444c8a641070f1ebe0640dd3675ead4c5a79c72cad0b973e7166cd9b2a5dc8f9360e185175e5019191945b7c98807c7d1a347d51b6fbca1b2b2b2cafd9c1b376e74028711040e00000000081d807a60f6ecd9efb76cd9f216bd2dd8b46953b91ef3de7bef150b14e4b498ddba752b767a4c39abc5e2c58bcbf57cbb76ed4a9c356b562881030000000007a103504f48f0d0b469d36173e6ccc93b59f0909494a456ac58512c7468dcb8b175b68af0f0f0a2db8e1d3ba6d6af5faff6ecd953e6f3c9948aa8a8a816a6698e217000000000e0207400ea9179f3e62dcbcece1ef4fcf3cfe796153cbcf4d24b2a3737b7e87a93264dd4983163acc061dcb8712a2c2cace83efd7cd6fe321da324ce1a0ea6698e888989799f4f010000008083d001a867162f5ebc2a2f2f6ff0dcb973734a0a1ed6ad5ba7f6efdfaff2f3f38b6e3bf5d453d525975c625d3efbecb355af5ebdac3358080927323333d5ca952b4f782ef71a0e040e000000007c113a00f5504c4ccc8ae3c78fdf347bf6ec1cf7e292696969321ac20a11dceebefbee62d7c78e1d5bec8c16292929eacd37dfb4b60e19e1f0dc73cf35d6178733a5020000004049386526504f49f070ebadb7de3873e6cc7f4f9830214c4ea7d9b2654bb9fda48f95e91665ed27231c9cc0415e87da060000005012463a00f5984cb5387efcf88d32e2e1bbefbe2ba88ee794c0c1394b05810300000080b2103a00f59c2b78385ed5e0c199525150507007532a000000009c0ca103d00048f050505030548287b8b8b84a050fcea2918a351c000000009413a103d040c85408091e66cc9821532d722bf258f7a2914ca900000000505e840e40032281415e5ede9059b366e595377890c0c1755a4c020700000000e546e800343032d5428287e79e7b2e77e3c68d9965edbb6bd7aec419336684eb8ba3985201000000a0a2081d8006488207d33487cd9a35cbd8b469537a49fbc81a0e515151617a3f19e1f03eb506000000a0a2081d80064aa64ae4e7e70f9e3973a6f1edb7df160b1edc67a92070000000005059840e400326231ef2f3f36f9e3d7bb6b17cf9f2f4a79e7a4a7df8e18729ce1a0e4ca9000000005015840e4003e7040fb1b1b1cd76ecd8a1162e5cd892c0010000004075207400a09a3469b2cef5f3c0d3b871e355d40a00000080aa227400a07272722e755f3f7efc787f6a050000004055113a00508661fcc97ddd34cd3ba915000000005545e8004079bddeeb7c6eea3f6cd8b066d40c00000080aa2074001ab8c8c8c86b0dc368ebba295f9736414141d7523b00000000aa82d00168e0bc5eef409f9b0c7b3b98da010000005015840e4003d6bf7fff60bdb9cbe7e6207b3b64f4e8d161d41200000080ca2274001ab08e1d3b5e6a18c6096b3798a699ab37cd8e1f3fce140b000000009546e8003460a669de5dd2ed866104d9f733c50200000040a5113a000d944cad304db3b4910c4ee820532c5a525b000000002a83d00168a0dab56bd7dfe7ac15beb2f5fd2db3b3b3fb515b000000002a83d00168a88ddfe339d9d409eb2c1686618ca2b60000000054aadf4115000dd61d27b9df3a7385699a03ecb35c000000004085103a000dd0adb7de3a406f9a97675f9962d1be7dfb5ba835000000001545e80034408661f4ade0fe67516b000000002a8a21d34003b468d1a267f5e659f76d1111114fe8cd145da26263639fa096000000005415231d0000000000805f103a000000000000bf20740000000000007e41e8000000000000fc82d0010000000000f805a1030000000000f00b42070000000000e017840e0000000000c02f081d0000000000805f103a000000000000bf20740000000000007e41e8000000000000fc82d0010000000000f805a1030000000000f00b42070000000000e017840e0000000000c02f081d0000000000805f103a000000000000bf20740000000000007e41e8000000000000fc82d0010000000000f805a1030000000000f00b42070000000000e017840e0000000000c02f081d0000000000805f103a000000000000bf20740000000000007e41e8000000000000fc82d0010000000000f805a1030000000000f00b42070000000000e017840e0000000000c02f081d0000000000805f103a000000000000bf08a60a80ea679a66d8debd7bc76564648ccccacaea99999919e6f57a03fa98f5b1aa5dbb76a933cf3c73ca9d77de3925908fd5300cb351a3464742434337e4e5e5cde8d7afdf1abe7500000040e0217400aad9debd7bffb271e3c6993939394d3a74e8a0a48487872b8f27f007160d1a34a84ed4b1d7eb35323232daa4a7a70f4a4a4a1af0c5175ffc909d9d3d72e0c081dbf906020000008183e91540354a4848787fdfbe7d2fb66eddbac945175da4ba75eba65ab468512702873af5834bd767f3e6cd55972e5d54dfbe7d43bb76edda5b463dac5ebd7a30b50300000004d0efee5401503d2470d065f0b9e79eab3a77ee2c5300a8941ad2a95327d5bb77efc61e8fe7ad55ab56dd408d000000008181d001a80632a562cf9e3d837bf6ec69fd05ded7f18c436a7fdc5b6ad79a27d5ced54fa8844d6fa89cf403545c356adab4a9ead5ab57b861186f7df2c927e7512300000040ed237400aa48168d4c4e4e9e2953294a0b1c7ede345f6524ef54de825c657af35556ca4f2ae1bbd7091eaa99040fddbb77f7060505cda13600000080da47e80054919ca542168d9421fe2549d9f7a5cacfcd3ce176092092f7aea502ab59972e5d5a050707ffe6d34f3fbd94da000000006a17a1035045725a4c394345696b386497319a414641a0fab56bd72e496f86521300000040ed227400aa282b2baba79ca1a23466415ee90f36bd54a01fb469d3a6b3def4a72600000080da154c15005593999919161e1e4e450410fd7974d49bb6d40400000050bb18e9005491d7eb551e0f4d29a07eb0157e1e84aa000000406dff6e4e1500fe15d2f89452ef0b6ec4080900000000f517a103e067adba5dae82439b9e707b504863d5ead47e5410000000807a8bd001f0b3666dcf564ddbf42cf1f6f076e7524100000000ea2d4207a00614e4659f705bfef163540c000000807a8dd001f0a3dcccc32ae1bbd755c6e11f4eb82ff3c86e95b0f1556b1f00000000a88f081d003f397a70934af8ee359595bab7d47db2d2f6a9f80d2faad484af94697aa93400000000f50aa79403aa998c5c38b4eb236b244379780b72adfd8f1dfe41b53b73900a0bef482502000000a81718e900543319b950dec0c14d4644ecfbf6652a1000000040bd41e800543319b95059a6379f0a04000000506f30bd02a866670d788a4a0000000000c548070000000000e027840e0000000000c02f081d00c0e5d65b6f7d352222e2276a02000000a83a4207c04fbef8e20bb57af5ea62e595575e51478e1ca9b6d778e289278a2ecf9b374fe5e79f7c21cadcdc5cb57fff7e75f8f0e1a2db3efae823eb76c74b2fbda476ef2e7e068eb7de7a4bedddbbb7c4e74c4d4d551f7cf041b98f5bf69f3b776ed1f58d1b37aa254b9654e8bdcb3166646454b90efbf7efdfcc0e1a5274313d1ecf5dfae6d3f9060300000055c74292809f2c58b040bdfefaebc56e5bb870a1bafbeebb8bdd261de7e3c78f97fa3ccf3fffbc8a8c8c54679f7db6755dc28b33ce38c3bafce38f3faa848404ebb26c0f1e3ca8929292d4f2e5cbd5d34f3fad7efae927b563c70e151717a75ab76ead7af4e8a1d6af5faf2eb8e00275f4e851e5f57ad50d37dca076eedca9060d1a54f49a3ffcf0831a3972a47579c58a15eada6baf556bd7ae55c3860db35e272a2aaad87b8b8d8d555dbb7655595959ea3ffff98ff5f88b2fbed8ba6fdab46956a020afef9080a267cf9e45d7e5fe89132716d587940e1d3a58d7dd218d1c67c78e1d55fbf6edd5ca952bd55ffef2974a070dfa79a24cd3940fa319df5600000080d001a873dca3078474f27da5a5a5a9e0e060d5ac5961df77d9b2652a3434545d7ffdf5d6f5871f7ed8badff1fbdfffdedacaa889810307aa6eddba59d7fff0873f5897a5381d7609199a366daa3efbec332b1490f0e0bcf3ce53df7fffbd75bfdc3e6ad428d5b871e3128f5fc203294d9a34b1ae7b3c1eb578f1623565ca94a27d6474c59e3d7bd43df7dca3366dda6405131234c86bc96809ddc12f16388875ebd6a9a953a75af5f1cb2fbf58752041841cfbac59b3ac6066e8d0a1d6be797979457523c72dfb6ed8b0418d1b37aee8f9246ce9d4a9d3493f8fc8c8c805fa35255d69639a265f5000000080d001a89be42ff9d2b9769310c057972e5d8a5d0f0b0b538d1a352aea68fbfafcf3cf557676b6d549ffeb5fffaa1e7cf0416be4c1b163c7acdbb66fdf6e050cb7df7ebbb5bf74ce251890e0e2fdf7df57fbf6ed53a79d765ab120243939b9a8f32ea3226404c5279f7ca25ab4686175fee7cf9f6f3d5e46515c74d1454541879069178f3cf2883565e2a9a79e52afbefaaa3a74e890759f4c8178f4d1478b1dbf0411728cdf7cf38df57cf21a2fbffcb2353d44466148783164c890a2fd9d0045483822f523c18c1c978cc2888e8e5637de78a31a3e7c78b17046dc75d75ded33323226eb8ba3746926418361187c39010000004207a0ee928e78e7ce9d4f18e9d0b76f5f75f3cd37abf7de7bafd2cf7dd96597a9d9b367aba54b975a230e2470909111b286844cc5f8e31fff586c7f398eb66ddb5adb010306a88f3ffe58ad5ab54a15141458d321a4c3efacef20a305a4c8f39e79e699d6940ee9d85f7ae9a5d6d4100924a463ffe73fffd90a176494c2bffffd6fd5bc79736bda87840c32aa418205998671e0c0012b209030e3f1c71fb75e43ae47444458cf73ca29a758e1814ca7906914898989aa4f9f3e561022a32ac4b66ddb8a4212095b76eddaa55ab66c698da410f27e468c1851ec3d4bfdca14132da9b2f5ac8f313e80bf62f2be72686940e5198611679a661a35015449746c6c6c3cd50080d001a86132b2e037bff98dead7af9f150648a7de992e209df7ca92904002839c9c1cabf32e2322fef9cf7faac183072bf92bbe1372c86bc83a10322a408487875b5b593b428203d9ca7d72591e2b230c1cb2c8a48406b2b8a374f09de3763af9e2dd77dfb5b6eddab5b3c20fb92e232be4ba0406121ec8a88477de79c71ac1e03c56d664b8e9a69bac20430405055961858c929069243366cc50999999d67a1212a6481d3ef3cc33d6880ee18c7a90692572cc1286a4a7a79f504f128454835303f82b762aad0ca81afd33f34a6a01a8164f500500081d805af4f3cf3f1775faab4ad65690051f6534c37df7dd67ad9d202302a4a32f8b39ca748ee9d3a7ab499326596b1f48275da6538c1933c61a8120eb31c8d40b9922e1acd3205319d6ac5953f41a3242408208599bc17721cc924838111212a27af5ea65052c32aa4246427cf8e187ea4f7ffa93b5fec2f8f1e3ad7d9dc5239dd041465bc81a153212424286d1a3475bc1897be482041312def892e7977a9545317dc9740b7ba44355ec0be0b0418e2d9ed605548a13367caecb5aaa03a894295401004207a0164967da21677d900e757591d356cae28eb278a39cc141165794d108975c7289d58197510ece629342a65ec8c8032972e60759985146135c7ef9e5d69926dc6424459b366dace90b42c202992a2241424924ec183b76ac1584c8140b5934f2c5175fb4a671c86938251890d7298d8415125ac8c80d19d1f0ecb3cf5aeb41c8e88dd2d6b470c86892175e78a1d8a2960e99c222ef63d1a2451d8e1d3b36dbe3f15c6d9a66eb8ad4736c6c6cf740fb5e4544443c61ffa227c3599fa0a501556a476b694740a5db11c103004207a036c9e290f2577d9936201d6ad94ae75a3ae5f7de7b6f959e5b463648f020231664b4c215575ca1befaea2b6baa4149246870a637c8da093202401672f45d0741c854055990519ecf792d67414ab7989898a2fb376fde6c5d96110d727a4e59cb41debbacd920232a9c452a4b23eb5cc8088d279f7cd20a4fe43965f485bc863bec90291f321d4416e394d10de79f7fbe3572c3bdd0a4afd75e7b4d56b48c94cb729accf6eddbbfa32f5e6118460bbea500000000a103502749275f16467ce8a187d4fffddfff598b33ca5400993e206b29c85404090c64ad075928d14d3aeeee5368ca628cb266824c9f90c7cae806092e6414828c289053674ac7de99bae04b1eef4c679000444639b8cf3e219cb520dc1d7819c520eb26c8340d5fcea93f655ac4e4c993adb5176ebbed366be4849c4d43ce4a21a310e4cc12b7dc728b9a3367ce0967e99029135207123874efdedd3a4da6bc17596f62c99225d62293e2e8d1a3eace3befb4a64cc8940f21efe7a79f7eb24eaf297f6d9175237c4fcbe96beddab5197a53b4caa67edc0b86614498a6d94a5fe5941600000000a10310f8a4a32eeb38481020679370c203e9e8cb5915e4b64d9b36599d6ef94bfec5175f5c6c2a817b6a84c3196d20e180ac9320231164ba84900ebbd31917ce591f1c3202c219e9205312e4ac13322542cc9c39d3dafa4e6590fd64da868c2890e919beb66edd6a6d254c915362cae80359e052168994f726c186040242c206091f640d0a9982e190d79470428210390da81cb79c7ad3f7f5e4f99de390511432da41420ee73d3df0c003d608090965ca1af5e04bef3f4e6fc6d901c454d334ffca080800000080d001086812229436d541dc7ffffdc5ae9f6ced0237a7432e532aa43821858c8c70c89a0a6e32daa2a8c1ebfd468d1a55144c388f93c527dd64744659c725679a7048e02064d4858c80709fe5424860e0bbd8a333c544d68e90c795c55d97b2bfef2941a5be65dd8caa888d8d7d54f20dbebd00000040f5f250054035372a4fcd362b77e050d2755fce592bca529120a432efddd9cf39a56779b9474a00000000a803fd23aa000000000000f803a1030000000000f00b42070000000000e017840e0000000000c02f081d0000000000805f103a000000000000bf20740000000000007e41e8000000000000fc82d0010000000000f805a1030000000000f00b42070000000000e017840e0000000000c02f081d80aa36228fc7f47abd544400d19fc73ebdc9a726000000805aee2f510540d5848585fd72ecd8312a2280a4a6a66ed79b386a02000000a85d840e4015858484ac3b7af428151140929292d2f5662d3501000000d42e4207a08a727272a6252626e699a649650486f8949494de7afb2e5501000000d42e42822e153f000020004944415407a08aaeb8e28a0da6696e3d78f020951100b66fdffea9fe3c0e5e7df5d5eba90d000000a076113a00d520272767647c7c7c567a7a3a95518bd2d2d296a7a4a4dce8f57a27521b00000040ed237400aac1c081037fd41dddc13b76ec384af0503b2470d8b66ddbf98661fc597f1edba911000000a0f6113a00d564c08001abf2f3f36fd9b2654b7a4242420a6b3cd498f8eddbb7bfba75ebd64bf4e5fbf5e7f021550200000004064207a01a49f050505070497c7cfcc6afbffefaf0eeddbb37a7a6a62679bdde803ff63d7bf6a8679f7d56fdf4d34f017facba3ef71d3972e43f3b76ec88f9f2cb2fb35252524ed3b75d4de000000000049660aa00a85e32d542362b57aeec939898385497fefa7a4b5dc202f9b8df7bef3d959a9aaa66cf9ead860d1b16e8d5dc5997c3bafca0cb1c168d040000000213a103e027d75c734d9cdec4d585631d3d7a74584e4e4eb65c963529162e5cd8383a3a3a874f11000000405530bd02809c7de352f7f5e3c78ff7a756000000005415a1030031c67dc534cd3ba912000000005545e800405ce773bdffb061c39a512d00000000aa82d00168e0222323afd59b36ae9b0ae47a5050d0b5d40e00000080aa2074001a38d3347d473918f67630b503000000a02a081d8006ac7ffffe72069b3b4bf9b93044ce6a412d01000000a82c4207a001ebd8b1a39cb5a2a9efeda669e6ea4db3e3c78f33c50200000040a5113a000ddb5f4afcc1e0f1c80808091f986201000000a0d2081d80064aa65678bdde6b4abacf344d8fbd9529162da92d000000009541e8003450eddab5eb6f1846db3276c9d1f7b7ccceceee476d01000000a80c4207a0810a0a0abae964bbc83f86618ca2b6000000005406a103d04079bddedb4fb24b88fc639ae600fb2c17000000005021840e400374ebadb70e300c23bc3cfbca148bf6eddbdf42ad01000000a8284207a001320ca36f05f73f8b5a0300000050510c9946b5193e7cf823ba73fa4c29774f89888898e2be213636d6a0d66ac7a2458b9ed59b67ddb7e9cfe709f99c7489d29fcd13d41200000080aa62a403aaefcbe4f1c4510b0000000080a27e225580ea121313b3c234cd63e5dc7d3f350600000000f51ba103aadbd293dc5f20ff98a6b982aa0200000080fa8dd001d5ca34cd774eb24b9efc6318c6426a0b00000000ea37420754ab264d9aacd39bd4327609d325392929691db50500000000f51ba103aa557474748e61181f9572b757fe314df3fdb56bd7e6535b0000000050bf113aa0da99a6f95a297759eb39783c9e77a92500000000a8ff081d50ed64ea84699a5925dc15a2cbfec4c4c455d41200000000d47f840ea8763275c2e3f144fbdcec4cad58c1d40a000000006818081de0175eaff763f775d334bdf6c5cfa81d000000006818081de017870e1d5aa137c9ce75c33082e5bad7ebfd90daf18b5eba9ce7ba2ea7247d8c6a01000000509b081de0173285c2308c4f7c6e5eb164c9920c6ac72fbe775d6ead4b8e2e4febf2ac2e17d9e5125d7e475501000000a829840ef01bdfb3581886c1592bfc47d6c97016ef94a0e14efbf277bafc629726baeca7aa00000000d49460aa00fe121616b63e2727a7e87aa3468dd6522b3562beebb2840efbeccb41aecb00000000e0778c7480df444747e798a6b9532e1b86b1475f4fa356fcea065dfeae4bb62e7d74b9902a01000000509b18e95047e9ce7cd8debd7bc76564648ccccacaea99999919e6f57a03ee38939393d5860d1bd485175e78fa983163cc403b3ec330cc468d1a1d090d0ddd90979737a35fbf7e6beaf0d7a29b2e97e9f28e2a1cd510464b01000000509b081deaa0bd7bf7fe65e3c68d337372729a74e8d04149090f0f571e4f600e5cb9f9e69b03b62ebd5eaf919191d1263d3d7d505252d2802fbef8e287ececec9103070edc5e07bf1affd2e54d5de6a9c2510fe2745a0c00000080dac2f48a3a262121e1fd7dfbf6bdd8ba75eb26175d7491ead6ad9b6ad1a245c0060e01df0074bd356fde5c75e9d245f5eddb37b46bd7aebd65d4c3ead5ab07d7d1b7b45597077499625f9faccb8f76f948978d7cea000000006a0a231dea10091c74197ceeb9e75a1d6554bf4e9d3a4988d378ebd6ad6fad5ab5eab60103067c58870edf499e76e992a80acf56f1675578660bdf7d00000000a0c63a29087032a562cf9e3d837bf6ec5962e0703ce390da1ff796dab5e649b573f5132a61d31b2a27fd001557094d9b3655bd7af50a370ce3ad4f3ef9e4bc3a74e8cd5c975fd165b42a1e38082f9f30000000809a42e85007c8a291c9c9c933652a456981c3cf9be6ab8ce49dca5b90ab4c6fbeca4af949257cf73ac1432549f0d0bd7b776f5050d09c3a74d8713ed7ffc52709000000a036113ad40172960a59345286fe972465df972a3f37f384db258048debb960aaca42e5dbab40a0e0efecda79f7e7a29b501000000001547e85007c86931e50c15866194787f7619a3196414042aaf5dbb76497a33949a00000000808a2374a803b2b2b27aca192a4a6316e495fe609329fc55d1a64d9bce7ad39f9a00000000808ae3ec1575406666665878783815510b74bd77d49bb6d40400000000541c231dea00afd7ab3c1e3eaa5a692085f54e38070000000095e9535105755f48e3534abd2fb81123240000000000b583d0a11e68d5ed72151cdaf484db83421aab56a7f6a3820000000000b582d0a11e68d6f66cd5b44dcf126f0f6f772e150400000000a815840ef544415ef609b7e51f3f46c500000000006a4d402f90679a66d8b66ddb466ddebcf9b6c4c4c43e070f1e6c929e9e1e9c9393a3828383cdf0f0f0bc56ad5a1d68debcf9577af77ffeed6f7fdbd9d03ec0dcccc32ae9c70f5456eade13eecb3cb25b256c7c5575387b880a6dca091850b64e9d3aa5e936a6ba75eb465a05000000a05a0464e82061c37befbdf7ca534f3d1579e4c891e0b3cf3e5bf5efdf5f75edda55b56ad54a858585a99c9c1ce3d8b163a13ffffcf369dbb76f3f6dd3a64db74d9c3831213333f3a9575e79e5b586f0e11d3db8491dfedf272a3f37b3d47db2d2f6a9f80d2faab63d06a8965d2f5586c1e0169ce8f1c71f8fd46d69e675d75da7d6ae5d3bedd1471f3d3275ead4686a0600000040bd0a1dd6af5f3fe6e9a79ffed7d1a3471b454444a8debd7baba0a0a013f693e0414adbb66dd505175ca0eeb8e30e63cb962da7c6c6c6be3476ecd8075352526e5cb264c9ffeae38726a31b0eedfac81ac9501ede825c6bff63877f50edce1ca4c2c23bf2cd47914993260d4d4848786bfcf8f11e694bbacd79e6ce9dfbdac489137367cd9af50e3504000000a0b202e6cfdea669062f5fbe7c757474f4ebbad3d3e899679eb1c284920287d24840a11f1774d34d379d151e1ebef5eebbefbeab3e7e683272a1bc81839b4cc1d8f7edcb7ceb514446382427272f1e3f7e7c90b437a71ddd7ffffd41a9a9a96f4e9c38f1366a0900000040650544e82081c3e79f7ffed5aa55abae7ae08107d40d37dc50a1b0c1d7c08103a533d5d8e3f1ccb9ebaebbeead6f1f9a8c5ca8745d7bf3f9d6c312151535eae79f7f7e7bdcb8711e2770709c7ffef96ac2840956f070efbdf7de446d01000000a88c80985ef1c1071fac5cb56ad54593274fb6a64b5487534f3d553df9e4938dfff18f7f3c1b191979342626e6edfaf2a19d35e029beb9a812091ce2e3e3e7df7ffffd1e19d95012b9fd81071e089a3973e6a23beeb863d89b6fbeb99c9a030000005011b53ed241d670f8f8e38faf1a3f7e7cb5050e0e79be471f7db4594848c8dcc8c8c8b3f8b8012b701871b2c0c121231e1e7cf0c1107d71f1a851a3aea7f6000000005444ad860e72968a952b57be78fdf5d7abdffce6377e790d19f1307cf8f0461e8fe78dda7a9f111111ff888c8c1cd2bf7fff60be72a84d13264c18b277efde0532a5e2648183438287871e7a28d4ebf52ed3dfe36ba94500000000e555aba1c3fbefbfffba9cf652d660f0a7418306356ed1a2c569bac334b296deea3f4dd35cd6be7dfbc31111116f49c76dd8b061cd6af2009e78e289a2cbf3e6cd53f9f9275fdb21373757eddfbf5f1d3e7cb8e8b68f3efac8badd574242824a4a4a3ae9737ef0c107ea8b2fbe2876dbb469d394eed096b8bfbcdec68d1b2bfc7e5f7bedb5128fb32193110e6969694bdd8b469697040f93264d0a090e0e5e367cf8f01ba84d00000000011d3ac82887eddbb7df2aa7c50c0909f1fbeb8d1d3bf6148fc753ab8b4a1a86d1526f46eaf7fe715050d05efddedf900062f4e8d161fe78bdd5ab575b6180941f7ffcb1e8b29483070faa0d1b36a8c71e7bccdaf7a79f7eb20281279f7cd20a2556ac58a1a64e9daa366dda645d5eb060813a72e488dab973a70a0d0d3de1b5ba75eb267f45572b57ae2cf398e6ce9dab525252ace77ceaa9a7ac63d8bb77af152ec86dcef138aebdf6daa2c04482120912dc45020cb95dc211b7a64d9b9e1056f8eed3904c9e3c79647c7cfc9b95091cdcc1c3830f3e18a63fff25040f00000000023a74d8b66ddba85f7ef925b8bc43bcabaa57af5ea18d1a353a4d77f4bb0748ddb7d165b4041039393987ed00a25aa760fcfef7bfb7c200e9cccb6812b92ce50f7ff883b5bdf8e28b258cb1f6edd1a387755d8285264d9a589dfdbbeeba4b858585a9162d5a58e143ebd6ad55e3c68d4b7dbda8a82815171757747dfdfaf5c5463f2c59b2c40a2f8e1d3b66bddee0c183ade0e0c5175fb49effa28b2e524f3ffdb4b5af8cae58b870a11562c871dc79e79dd67349c870e38d37aa75ebd659e59ffffca7f57cb1b1b145c18514fddd5269696945d7fffef7bf5bfb34d4c061fffefd0b640d87ca060e0e69af93264d227800000000502eb5b6c6c0e6cd9b6f930e4c554e8d5951e79f7f7ed237df7c738bbe3823c03e8766760031ba43870ec9919191abf4f5058d1a355a1b1d1d9d53d927fdfcf3cf557676b63582e1af7ffdabfc95da0a06a4932eb76ddfbe5d75edda55dd7efbedd6fee3c68db3460d040707cbd417b56fdf3e75da69a7153d9f4c81484e4e2e162ac875d95fc8a805b92c9d7c91935378e8fa3d59dbf6eddbab4e9d3a59a187ecf7c30f3f288fa730f79263d0ef577df8e187d629536511d011234658f7c9888b7beeb94775e9d2c52a31313156a022de78e30d75ca29a75897070d1a54746c32aa41de9bfc755ef4ecd9b3d87b6928ec4523179467d1c80ab4232b7898366dda62fd5dbd597f1e2bf8510a00000020a04287c4c4c43efdfbf7afd1d7bce4924b5a7ef3cd37575677e8608f9e185d4d4fd7c634cd08795ae9b40f1f3efc7fee35152ae2b2cb2e53b367cf564b972e5553a64cb10207991a21a3059e7ffe79f5c73ffeb1d8fe9d3b77b63afbb21d306080faf8e38fd5aa55ab54414181cacaca522fbffc72b1f51d2ebdf4d2628f97304382031925511219e520a18684171236346b56b8ac854c0391e717afbcf28a75dc32aa42483071e0c0016bb485acfd20c1884c9df0f5d0430f59e184f3977c795c9b366dacc7ea4eb74a4f4f570f3ffc70403746fd3d32f546e684cc0b0b0b7b3f3a3a3aad2acfe72c1a397efcf8a2c041467f4880e36bce9c39c5ce1e239f878c2ef125536f5ab56a65050fba3e1bebcfe4ddc8c8c8a1040f000000004a526bd32b0e1e3cd844ce2c51934e3ffdf4267ad3c70f4f2d81c394324aa5198671868c20a828e934ca8803092e962d5b668501321541d639304db3684d041929e08c4810e1e1e1d6f6f8f1e3d65409d9caa804b9dcb16347abd35a916370c8b40d19b920231464dac419679c515424e478e79d7754dfbe7dad11184ee0909a9aaae6cf9f6f1de79a356bac6061ebd6add6348c92c8ba1412784839efbcf3ace0c4b92caf5147f4d5e50d67ca8d2e7d2bf324a52d1ad9b2654b2b74902934453f043c1ef5d24b2f157bbc843feeb5566434c9c89123adc0c1619fd5a2897efc52a65a000000002849ad8d74484f4f0f960e504dcacbcb6bab3bdcf9ba23f744353fb53b58883ac9fd150d1df6e8cef8e9157d9c742a65ba818c66b8efbefbac5102d2b9945106b2b681ac87307dfa7419266f0509320542a6538c1933c6eaf42f5ebcd89a9e201d7ca7833a64c810abf3ef2601827448e5b92598908eaa8ca6484c4cb4464538a30be4399d29111240c862960e1949217f6577a661d8df0f6baa85acf1307af468f5cd37df5823207ca77c38d333848ca270a676c8d411392e5993422e4b6052871cd79f7b884cb7d19747ebefeb3a7d795ee3c68ddf2fcf749ba8a8a851f1f1f1f3658443496b385c71c515d65a1912d208f94ec8629e124849f0238b856edbb64dda4be10f89e060d5bc79f31247b0c8080afd1987e8ef57ecf0e1c323162d5af4213f5601000000d47ae8207f5d970e614d92350874672e585571f44159fd3ddda13f21d0d09dc672bf9eee5ca6e9635ca5cbc2468d1aad904ee6983163ccca1c8c7424659ac19e3d7bac4ee6f7df7faf860e1d2ad34c8a461c38418070c20229d249974e676666a6bafcf2cbd57ffef39f125fc35977419c6c7a8543020859b4d21d1648f050acd77dfcb8b5ce838c72904042ce60b17bf76e6bc149ddb92df13b249d63e7b5e53dc8480799c22145c28aca90e7b15ff311fd9924d9415092fe9c9cce7fbc1d9c242f59b224a39abe478d64348a4dcefbd94fbf663ffd7e33f477295abfd6f3fab5fe5756e070b2351c649a8a9c29c4198d226b7fc8694665ed0b39c3887b948a844e77df7d77a9ebafc822ad122e49f0101919790b532d00000000d47ae8a03ba7a6ee441935193ce88e6ef2d2a54b5bea0edcd37e7a89e84a3e4e3aabd2515bd4b871e355559dcbef905100123cc88805e938ca5fb8bffaeaab13d6627048d0e074da333232d4f2e5cbad5102ee60a13ac85928641d876215171d6d0dd777d61570af2f2064d4822c4229c5217fa997b36038ce3efbec12473a481d4867ba3224a8dabc79b3040dcfb882a113f6930eb99cfe55b210798baecf35d91d4ed8d7339daab0f777efe72bd4153ec82218e3f46b8dd3aff5a13ea6d7f3f3f3573961c7e38f3f1e599ec041c8a812f9ac65dd0e091c84040d32b24446993864ba8d8c3039fdf4b207db48f03069d2a482e9d3a7c70c1f3efc76463c00000000a8d5d0a179f3e679696969a1ee21f5fe16121292a23b6a39258d46a805d2515caacb7f74c7f8c3aa9ca5a23432bae1de7bef55e3c78fb7feea2ff3f4e56c13a575c065d145f799276494839c5ad34d461e94978c60f8ef7fffabaebcf2ca62b74b70e03b1a424ea7e91b3438cf21640ac0db6fbfad1e79e411590fc41a51216b5db8430759f3c1e11ee9501512d0c82889b8b8b8674dd374beacb275d2b2eef6b68d1d0a84b96eab4e4ef8200188571fcb0d52ecb0e3c7162d5ac42424243cee5e34f2646ebef9e6a2339c0819d922d35edca18a8c1eb9f5d65bcbf57cfa751b3ff8e083de193366bc337cf8f0db081e00000000d45ae8d0b265cb04dd993ba32643876ddbb6c924f682da7acf3275426fd67a3c1ee7749869fe7a2d0907fef4a73f59231ba4036ef58ebb7757c3860d2bdac7bd1e82d3c176c200e9ecbffaeaab6aecd8b1d6f59933675a5ba7132f7f0d97451ddda1842c0c2acfe9acd720e1804ced90bf94cbd40d879cced209371c12709444c206794dd97fc28409853d7efd9d79f1c51795eed45aeb3e94443ad012a25476848343467fc8ba087ffbdbdffe5e9efd478f1e1d969393d3c1febc9b1986d1a6947042b4b7438a66f6edfdcbf93df25d00f62cfd794449e852d21a0ea591c042022959dbc3a97f77e0206baec81a1fee45274fe6b7bffd6dd3871f7e3863dab469040f000000006a75a4c3e7dbb76f3f43d617a829ba032e3daacf6be1ed4ed69dcff8b0b0b0a5fe18d15012a7932f532aa40859bf41fe72ed908ebb9b7ba480ec376ad4a8a260c2799c7450edcf4ff5ebd7afd8e37d4745c8f592a672c8a80679bc5b69eb4048e02043fedde49864048794323affc5828e9a627fbef19579ac7dcacc0a93fa90b53a2a123838249491692d326a44021ef77376e9d2c55a58b2a27af7eedd6cd2a44929d3a64d5b181919399c351e0000008086abd64e9979f4e8d167e2e2e2bcbe0b08fa51ceeeddbbcf5285531a6a546c6cec53bae3f5764d050ea571070e255df75591bf7057846fe0e00fb51138d404c3308ee8cd225dfe14141474aedc3670e0406baa4465c9a9307dd7a990eb37dd7453a59fb34f9f3eadfaf5eb97ae9fe7e3d1a347b754000000001aa45a1be9f0d4534ffdf4c0030fecddb2654b8fcafc85b6a256ae5cf9aed7eb3d353636369e8f1d81a68c510e12547dabcb071e8f67d5c18307b7af5dbb36dfb9332a2a6ab4be3ebf77efdee55ecbc1d73befbc236146b1e041463ac842a2e79c734ea59e73f3e6cd87d6ad5bd75c3fef75fe9c460400000080d0a154478f1efdbbeef0bca33b4bc1a59d8eaf9aa42d58b0e01cdd017a8e8f1c814c1689d476e8ed7bfaeadab0b0b0f5658d90993265ca82471f7d347bd6ac5931f7dd779fa7a201dece9d3badb539dc532b848c40920534376edc58e1291612384c9f3ebdb17ece118b162d626a0500000040e8503b5e7ffdf52563c78e9dfcf1c71f9f7fc30d37f8ed7566cc9821a31c7a262525c5f29123404dd6e5c7468d1a55f894a953a74e5d3c61c284dcb973e72ed5dba0f28e789060e185175eb04e8fea708f78387af4a87ae38d37acd10ee59d6ab371e3c643cf3df79c1338b08824000000d0c0796afb0074c7e68fcb962dcbdebd7bb75f9e7fdbb66d1f7cf7dd77d7ebced49fddc3d2814022eb7ee8b2b4b2531166cf9efd7ecb962d6fd1db824d9b3695eb31efbdf79ecacaca2aba1e1212622dfe295b879c0564f1e2c5e57abe5dbb7625ce9a352b94c00100000080a3d643075963213737f7cf3367cecc3a7cf870b53ef7810307fefbecb3cff6310c63524c4ccc8f7cdca8cf247868dab4e9b03973e6e49d2c78484a4ab24e43ea0e1d1a376eac1e7bec31151e1e5e74dbb163c7d4faf5ebad539f9645a654444545b5304d730c8103000000008727100ee2edb7df5e98919131fe1ffff84746758d7890110e0f3ffc70d782828217e5cc117cd46808e6cd9bb72c3b3b7bd0f3cf3f9f5b56f0f0d24b2fa9dcdcdca2eb327d62cc983156e0306edc3815161656749f7e3e6bffd2ce34e3ace1609ae608ddd6dee75300000000e0f004ca812c5cb870fed1a347fffce4934fa62f5fbe3cb30aa7d24c7beeb9e7a2a74e9d7ab1d7eb9db268d1a267f998d1902c5ebc78555e5edee0b973e7e694143cac5bb74eeddfbf5fe5e7ff3adbe8d4534f55975c728975f9ecb3cf56bd7af5b2ce6021249cc8cccc9433c09cf05cb28683b36824810300000080800d1dc4a2458b627547a8b7ee347d73efbdf71edabc797376051e9ef3e9a79fc6de7efbedfffbf6db6fcf300ce3aad8d8d8683e6234443131312b8e1f3f7ed3ecd9b373b66cd952747b5a5a9a8c86b04204b7bbefbebbd8f5b163c7163ba3454a4a8a7af3cd37adad434638c8a291fae270a65400000000284970a01d90acf1a0377f888888b865c68c19f78486869e7fd659671deed7af5fb3d34e3b2db455ab561d64e8777676f621dd813afafdf7dfef5eb76e5dd0eeddbb7b16141474d18f9d979494f4368b4682e02166c5adb7de7ae3cc9933ff3d61c28430399d66cb962de5f6933e56a65b94b59f73960a091ce475a86d0000000075227470850f4bf566e9881123ba6cd9b2e596b8b8b8dfe9eb7d75c9d145269cb7d0254f1739bfdf67badc630716006c32d5428287d9b367fffbfefbef0fb9f0c20b83aafa9c1238b8ce5241e000000000a054c1817e800b172edcaf37b3ed02a0825cc1c3f209132634aa4af0e04ca9e0b49800000000cac3431500f59f040f0505054367cf9e7d3c2e2eae52abb43a8b462ad67000000000504e840e75e143f2784cf7a27ea839badef7e94dbd581f44d65e90e061c68c1939df7df75d6e451eeb5e3492351c0000000094bb3f5b0baff99c2e6d2bb07fa82ef79d649fd375f9cb49f699a64b335d7ae972997ddbb5bab40ef40f292c2cec9763c78ef16dad05a9a9a9dbf526aebebc1f090cf2f2f286cc9a352bafbcc183040eaed36212380000000028b79a0a1d22751964975cbbb32f971fd3a5b36bbf1b7439d52e4ed020fb9f59c2735ee67aceb37439cf755dca9f7cf6977021431739c3457bfbb611ba1c09f40f29242464ddd1a347f9b6d682a4a4a474bd595b9fde934cb590e0e1b9e79ecbddb871636659fbeedab52b71c68c19e1fae228a6540000000008d4d04142868fecf2882e6fd9973bea72d8b59f746af6d9658e2a3c4b858c4e08b1b7035cc73cd1f59c52e25d970fd9d7c5e9760821e1c67daec041387316ce0ae40f292727675a6262629e699a7c636b567c4a4a4a6fbd7db7bebd31091ef4f769d8ac59b38c4d9b36a597b48face110151515a6f793110eeff3750000000010a8a18347151f85e094eeae7d3aab13472a0cb60387247b9f51aea0e00e5d2e52852318a49cedbadc559735f67e7bec20e2673bc89040e2425d26dbc725533dfeae8a8fb80828575c71c506ddf1db7af0e041beb13568fbf6ed9fea7a3f78f5d557afaf8fef4fa64ae4e7e70f9e3973a6f1edb7df160b1e9c351c0a0a0aee20700000000010e8a18357151f95e014390da6b3485fa27ddbf9aa704ac51bba2c5285a7f5fc9f2a9c1a91e37a4eb92ceb381cb3cb71d7e5eb4b380619353144158e74f84e977fdac7f5ffec30e340207f5039393923e3e3e3b3d2d3d3f9d6d680b4b4b4e5292929377abdde89f5f97dca8887fcfcfc9b67cf9e6d7cfae9a747972e5daad6ac5993ecace1c0940a0000000075217410b280e3cdaaf86806b9ed145730116c87023b5cb75fa27e5d77c1f7786594c200bb74735d76ef77a52e0b74e9a48bfcc5f690cf73bc57173ea8810307fea83b818377ecd87194e0c1ff81c3b66ddbce370ce3cfbadeb7d7f7f7eb040ff3e7cf0f7bf7dd77d52bafbc124ee000000000a02e850eb2585d1775e28887deaaf8428eb2e0e4d3aa70d4832c3229a313642ac44afbfefd3ecf7b4895bca683fbfc92dfe872a72a9c6651a70d1830403a87b76cd9b2253d21212185351eaa5dfcf6eddb5fddba75ab045df7ebfa6e309d6e091e0cc3582a97654be000000000a0ae840e6dcbd9e1977061b42ec374b9ca0e1886eb22a76d70a660b4f0798c8c8c70af0fe15c4e72ed93e37abcdb65f6e3c539aaf0d49c752278282828b8243e3e7ee3d75f7f7d78f7eedd9b53535393bc5e2fdfe64ad0f5b6efc89123ffd9b16347cc975f7e99959292729abeedea861438384cd3fc9f7b0b0000000055155c03af71932e2fe972852eed54e1e9301d4d5d9737dba1c3cff675590872822e2fa8c25366ee2f2174709f16534eb7f9917df923d7edadedadf3581974af2d8800002000494441543d71b7fdd87c3b6c90e79791182bebc28726532d64b372e5ca3e8989894375e9afafb7b4df1b2a4616109533a8fca0cb9cfaba682400000000d4c7d0414e89f9952a5c04523a76321d629febfe65aecb5e57e020a7c79490e2253b1890e3fc54977bcb78addc526e97e91b32bd62b37dfd4b5d649ebe4ce1f83f55389a427c5dd73ebc6baeb9264e6fe2f81a03000000000291bf438744bb886f4bb87f61298f9390c23d5ae17b5d7e7792d79a50c67dafbb2e1fb68bf3bcdff3350000000000a0fa79a8020000000000e00f840e0000000000c02f081d80facb390347a86bbb906a010000005053081d80fa6b812a3ca3c94ff67559acb51fd502000000a0a604530540bdf0902e77a8c2d3d066aac233c58cd52547971b5dfb655355000000006a0aa103503fc8b489177479599751ba9ceeba2fdddecaf48a235415000000809a42e800d46f17a9c200a2b5bd1d4b9500000000a829ace900d46f49ba7c656fc7e9b29d2a010000005053081d80faed67bb485b9f4e7500000000a8494caf00ea07392bc514fbb28c669090e18fba2cd5e51c5de6e8f212d504000000a026113a00f5c312bbb8c91a0eb7e8d2449749baccd665025505000000a0a630bd02a8bf9ad8db2c5da2747954fd3a1a0200000000fc8ed001a8bf7c178d74c20700000000a811840e0000000000c02f081d0000000000805f103a000000000000bf20740000000000007e41e8000000000000fc82d0010000000000f805a1030000000000f00b42070000000000e017840e0000000000c02f081d0000000000805f103a000000000000bf20740000000000007e41e8000000000000fc82d0010000000000f805a1030000000000f00b42070000000000e017c15401d0f00c1f3efc11c3309e29e5ee2911111153dc37c4c6c61ad41a000000808a62a403d0101bbec713472d00000000f07bdf832a001a9e98989815a6691e2be7eefba931000000009541e800345c4b4f727f81fc639ae60aaa0a0000004065103a000d94699aef9c64973cf9c7308c85d41600000080ca2074001aa8264d9aacd39bd4327609d325392929691db505000000a032081d80062a3a3a3ac7308c8f4ab9db2bff98a6f9fedab56bf3a92d000000009541e8003460a669be56ca5dd67a0e1e8fe75d6a090000004065113a000d984c9d304d33ab84bb4274d99f9898b88a5a020000005059840e40032653273c1e4fb4cfcdced48a154cad000000005015840e4003e7f57a3f765f374dd36b5ffc8cda010000005015840e400377e8d0a1157a93ec5c370c2358ae7bbdde0fa91d000000005541e80034703285c2308c4f7c6e5eb164c9920c6a070000004055103a0038e12c16866170d60a000000005546e80040858585ad775f6fd4a8d15a6a050000004055113a0050d1d1d139a669ee94cb8661ecd1d7d3a8150000000055154c1500fea13bf1617bf7ee1d97919131322b2bab6766666698d7eb0dd8e34d4e4e561b366c50175e78e1e963c68c3103f5380dc3301b356a7424343474435e5ede8c7efdfaada9235f895eaaf074a4dbedeb0b75f95e97a7692df5a71dd515b423da11ed8876443ba21dd18e40e800d461fa3fa5bf6cdcb871664e4e4e930e1d3a2829e1e1e1cae309ecc14537df7c73c0d7adfe0fded0ffe1b7494f4f1f94949434e08b2fbef8213b3b7be4c08103b707f8a1cb2f7467d9975beb9263ff82f7ac2ece1a1a1efbe7f27f694575b71dd505b423da11ed8876443ba21dd18e5053682940354b4848787fdfbe7d2fb66eddbac945175da4ba75eba65ab468c17f4cd5f5434bd763f3e6cd55972e5d54dfbe7d43bb76edda5bd2f1d5ab570f0ef043cfd725cbbe2cbfd8dd695ffe4e975fecd24497fd7ccab423da11ed8876443ba21dd18e684720740050e27f4cba0c3ef7dc7355e7ce9d65c81895e2679d3a7552bd7bf76eacffd37a6bd5aa5537d491c39eefba2cbfe4edf329b423da11ed8876443ba21dd18e6847b423103a00f8950cbddbb367cfe09e3d7b5a89adafe31987d4feb8b7d4ae354faa9dab9f50099bde5039e907a8b86ad0b46953d5ab57af70fdcbc05b9f7cf2c979017ca8f29fe7df75c9d6a58f2e17f2e9d18e6847b423da11ed8876443b429d6c472074006a8e2c2e949c9c3c5386dc95f61fd3cf9be6ab8ce49dca5b90ab4c6fbeca4af949257cf73aff4155e37f50ddbb77f7060505cd09e0c3ec66ffa297aa4bbafdcb1e6847b423da11ed8876443ba21da1eeb523103a003547563396c5856448584952f67da9f273334fb85dfea34adebb960aac265dba7469151c1cfc9b4f3ffdf4d2003dc47fe9728f2ef374d9a30a17f302ed8876443ba21dd18e6847b423d4bd768472e2ec15403590d327c94ac6a5cdf5cb2e23f596b41cd5a75dbb7649070e1c18aa2fae0fd043dcaacb03ba4cd1254a97c9ba5ce6fe3ae9d29776443ba21dd18e6847b423da11ed887614f0ed08840e40cd90f335cb7f4ea5310bf24a7fb0c9399eab539b366d3aebff9cfa07e8e139a3cb76e992a80a5707ffb32a5c49dc771fda11ed8876443ba21dd18e6847b423da51e0b62354f0070e802ac8cccc0c93f335a3f6e9cfa1a32a5c142b1035735d7e4597d13ebfe0092fed08b423da11ed8876443ba21d21e0db11ca89910e4035f07abd9caf3940d89f43a0fe6c8bf3b9fe2f3e31da11ed8876443ba21dd18e6847a893ede804c3870f7fc4308c674ab97b4a4444c414f70db1b1b10de23cacb426a00684343ea5d4fb821b91a403b423807604d08e50e73bd71e4f1cb55042bd500580ffb5ea76b90a0e6d7ac2ed41218d55ab53fb514100ed08a01d01b423d4713131312b54e122ace5b1bfa1d40ba10350039ab53d5b356dd3b3c4dbc3db9d4b0501b423807604d08e500f98a6f99f72eeb7a2a1d409a10350430af2b24fb82dfff8312a06a01d01b4238076847ac234cdd74eb24baefc6318c6c2865227840e809fe5661e5609dfbdae320eff70c27d994776ab848daf5afb00a01d01b423807684baad499326eb0cc3282b810ad525392929691da103802a3b7a7093fe8fe9359595bab7d47db2d2f6a9f80d2faad484af94c9b99d01da11403b026847a8b3a2a3a3734cd3fca4ac7df4fdefaf5dbb36bfa1d409a7cc04fc4012ee43bb3eb212eff2f016e45afb1f3bfc836a77e62015669d9218a01dd18e00da11403b421d344f975b4a081b0a0cc308f2783cef36a4ca60a403e007927097f73f263749cef77dfb321508d08e00da11403b421d2553274cd33c61e10f091cf4667f6262e2aa86541f840e801f48c25d59a6379f0a04684700ed08a01da18e92a9138661c494f89d30cd150d696a85607a05e007670d788a4a40b5ebd4a953dac1830755b76edd8ed18e00da11ed08b423da110297699acb0cc318e3ba4916f9903ffa7fd6d0ea82910e0050073cfef8e391a9a9a933afbbee3a75f8f0e1698f3efae8686a05a01d01b42320301d3a746885dea4faf4bd93bd5eef870dad2e081d0020c04d9a3469684242c25be3c68df3dc71c71deafefbeff7e8ffc85e9b3871e26d35781857e9f2ff7cca5ff874403ba21d8176443b024e644fa158e373f38a254b9664103a00000286fc4529393979f1f8f1e3832eb8e002ebb6debd7bcb2f7a41a9a9a96fd6e02f7a77ebf28d4fb9814f08b423da116847b423a05473dd570cc378b7215602a1030004a8a8a8a8513ffffcf3dbf21725e7173cc7f9e79faf264c9860fda277efbdf7de54438734c0a764f1298176443b02ed887604942c2c2c6cbdfb7aa3468dd6123a000002e617bcf8f8f8f93274d5f7173c87fc85e981071e08cac8c85874c71d770cae81c3fac8a714f0498176443b02ed887604fc6ac488115d860f1f3e2e222262494e4ece3655b880a430f5f5cdfabe65fabe87643f420700406dfd8237c2f9054f7e912b8bfc85e9c1071f0cd117178f1a35ea7a3f1fda209f72884f0bb423da116847b42340a9c8c8c821ba7ceaf57a7f320c43a655dca2cb19ae3eb7a14b777ddf10bd9d5e5050f0734444c41afd9891840e00801a3361c284217bf7ee5d2043584ff60b9efb17bd871e7a2854ff27b74cffc7756d351fd230fb17bab7ecebc1ead7d32dfffff6ce044caea25ac077b20e8b04044414d9dc50793e101141560d8bec5b08915d041145c1bc604041106533aba0a820044848802041f645414141206c891b2a0659c21ac29e40c8bcfaef74353597ee9e9ecc3ef9ffefab6f7aba6fdfbe5d5de7d639a7ce39755368478636d5f9449423e5489423e5489646f6dd77dfb5c378bf812d32431b1adaa036bc7deb70fcc5e11cb70f1b36ec433a1d4444a453614569fefcf9d3d3225df582a2376ad4a88103060cb872f8f0e11d5950ebf2ac397475d3d06ecb9af36687646f87b4fe3cb411d9dba18322ca917224ca9172244b05618cefdbaf5fbffb9a9a9ab68fcff5efdf3f4f393afcf0c3b333cf3c33fbe52f7f994d9d3a35fbd5af7e958d1d3b360b72956db2c926d9c08103d3536d1ede777f5f8d7ad0e920d2c5fcfce73fcffef39fff64fff8c73fb25b6eb9a5ea71f7dd775f76dd75d76537dc7043d5f6d39ffeb4eafbb9b9fdf7bfffadfbbab896193366547dfda9a79eca1e7cf0c1f2ff3cfecd6f7e53f578bee382050bf2c7afbc527967a059b366bde339bed7a2458b96ba7171c20927ec3f67ce9c8b9644c14b15bd912347360e1a34e8f20e56f4560ded7fb3b70b75f1ff5a5973c8e099a1352a47ca9172d4fbe4484439126997c361e77efdfa4d5ebc78f14ad1d9b0f3ce3b67e3c78fcf468f1e9d6db3cd36d9073ef081ec5def7a577efcb2cb2e9bbdef7defcb36db6c332289b29ffce427f9f1bcafc4f2443d8c1831e22b3a1d44648979e18517d8b3375b679d75b28f7ef4a32d8c8dbffce52ff9eb91bffded6f59b891653becb043b971b35a71c515f3c79ffffce7b3d9b36757fdac2953a6648f3ffe78ddd7f6f4d3b5d321dffbdef766e79f7f7e76efbdf7e646cea44993b270932d1b6e5ffce2175b18675ce7d0a143f3638e39e698ecdffffe77fe3adff39c73cec91f73ae679f7db6c5e7bcf1c61bf9ebc0f56330d2171c7fdc71c765cf3cf34c9f54f0c277bdb05691ae7ac1b33e6ad4a88e56f40eca9a4357d72ffdcf8ff66868ff0aedff425ba01c2947ca51ef922311e548a45d0e07221c66343535e51e039c09a79d761a4524b355575db5ae7330c7733cefc3391109e73cb7af453ce87410e9428e3ffef86cbdf5d62b1b188f3cf248f9312b9aac82b666d0cc9f3fbfaecf7af8e187eb3e16306a1a1b1bdff15cca77bffbdddc7099376f5e76e49147e6c773ccc73ffef1ecfbdfff7eb6e69a6b968f5d69a595b21ffde847b941c4311888ef7ef7bbb37ffef39fb9a1b7c61a6be4dedd7863befbeebbf3d73022b7db6ebb7cc5f8ef7fff7bfe9ddff39ef7e4e77eeeb9e7f2c77d094258a382576fce6c6b94425b1b070e1c785907e4d4ae1eda32a19d1ddadaa11d1ada7a59cbd5a434af5639528e94a35e204722ca91c892410d87fefdfbff2c3a1c98734f3ae9a4168e83b6c0fb783ff292381ece0932b35e5fe9338552a48b60a5116321e5cd37df2c3fc650c0782872cd35d7640306348b2a8607215a37df7c73366cd8b09a9f476875bae25be4f9e79fcf6ebffdf6b281c4caf1061b6c507e9d15515ebff8e2e67a4dbffbddeff2303042c779efca2baf9c9d7aeaa9b9e1c3357df6b39f2dbff74f7ffa536e2c6db5d556f9fb060d1a94af36879b7476c41147e486e195575e991b511890f099cf7c263bebacb3f26378ef37bef18dfc7b5e70c105e5731e74d0417d6a4cc4225d471d755459c1c3c0fddad7bef68e63e9fbd473feda6baf65871e7ae83b8e23558071c6c475ecb1c72e73e699675e1126adbda64e9d7ac3125ce26aa16d19da29713866cd2b4cecc34e55e69543a358122b4ca31976ca9172a41cf57c3912518e44969c30179f17532a88701839726439856249210a93940b9c0f8f3df6184f916a716ef8bb459fe833878d48e7c3caeb873ffce16c8b2db6a86ad854bb5961401106ceaa2506c6a73ffde9bc084dadb04742ab39eea5975eaa7a0cc6ceeebbef5e0e39e71a502ee2ff6bafbd761ed61dc1608bc61ca1d9279e78626ee81016f6831ffc203774c8af0772d50e3becb03c071d8328cd2d8f861facb5d65a2daee9631ffb5876fffdf767575d75555e74270d33e706bcf9e69bf7993151ad4817a176fc0e4c3ec9e496d73048a17fd202441898fbefbf7f0b83bc54457cd9f0fee94b18da4aaec0a5c5e1557aeeb0d0f66488a2af665d10d2aa1c2947ca918872a41c4977c2b698614efe028fa9c580a3a0bd0e87d4f14091c9a4c6c3e67d25cd42a7834817401e37c6128603137a3448088de62f46c8a69b6e5ab3f0db983163f2d5cb7a605594506dce576feef6abafbedac29061e5220d131f326448b6dc72cbe5557859cddd7aebad730386c71839282225cf6c0e157aefb8e38e6ccb2db72c7fafd5565badfcdd59914d3f8bb0f08f7ce42379d83c461437dc7beeb9275f0d8ec65dad15e7ce24f4fbf79864c277ee90e8b0a0e01d54ab48177db6faeaab97ff67dcb0aacd0a3d6094520f20aef0f3bbadb0c20a79bf1661c5ead8638fa58af8b40e2ee6d5e9fda41c2947ca918872a41c490f1b1b5f8f0fa8c3b4a42915d5e07c69c4665353d357753a88489bc068a09a3eb9e7ac68aeb2ca2ae55c74c2c29f7cf2c98aefe3f54f7ef2932d72bd6af1dbdffe36db75d75db3bdf6daeb1d2b1295c0a8f9c217bed0e2b9975f7eb985e716650183e9831ffc601e46c94d915560564defbcf3ceeceb5fff7a8b155df2dbf84e8484c79c76be1fe1f1a79f7e7a6e1c45f0ecf2fd6ebae9a6ecaf7ffd6b9e737ed14517e5ca0e461270ee73cf3db7bb7eba53d87b39187b2f84c98aaac23b0c1b366cf9762878e7b756a48bb0f87475e9f5d75fcfce3befbcfc7761ec6060a6fdc7b64c8967bc05a16f074545af13f64dafd44f2f857ebaa23dfda41c2947ca51e7ca1174f62e309c3b75d8b11b0cc5502b41245334648bf25e2c945a0f442a55833150ebf5780cb55720dd71a62dbbd928474b871cd58250f9083252cfae428c4d0a00a7e31ef94bc72cb2cbdc90421a1f3257099ccdb5764aaa36a7a5bb2691a6478a5e6b141ddb6d29c6dcd36568bffdf65b23fcd986c78c719c0e9d014ebb247a68736a48e87410915661e2e066cf2a66ccd9c670480bccb11a4ac1b8e22472d75d77e59378a555836a377b261d1408f2cc58e12c9eb3c8d9679f9d1d72c8212d9e7be08107de913bcff57313c400a2aafff5d75f5fce334f6192a272fe8b2fbe58fe6ec0f7c3e879f4d147b3030f3c300f294f61b524aee0f21d8ad57f518c8b45f9ba9286860626a5fdc364757df8ce8f8589ea4226ab830f3eb8ae2dba4e3cf1c41151c16bad4817abfaf4c332cb2c537e0ec58e3e4cc3fd316859dd5f77dd756b9e0f456fd4a851e1b2fb4dedec15a6d04f5cf49ef4539894e7863ebaac2dfda41c2947ca51e7c9513ac63b7b1718ce7dc00107940d17a28770b85562f2e4c9f998666c623c452707639c94a808b2c87968d46ab9f0c20bb33016ca4e48be0772356edcb8aa460fd146450747f118e428ae60b2734c34f8b89eee941fe5a867c95125189b38a76814f28d8f69cc59388b29280c38e118b3a4d7e194601c53e7273ad619df8c79eedbcc13a94cc608148e03e499e7f89c628d8d69d3a6e532ccef76f9e597e79f171d86c86f8c864bf9c4273ed12232f08a2baec8ef1545b9c19948f41ed74abda26f7ffbdb2d1c9238adaa39437a9b0c2d5ab468f7583c12b929ceef1d05f7d6822370efde6e0b197224d205a0f4b3625aba61e55bd6f1dcfbdffffe5cb10b37b9b26733854980a2744c14dcec9998bef295da5bf77eef7bdfcbce38e38cf2ff4c6cbbedb65b9edf5da9623d4a1aab12c58afb847817573e520ffd430f3d947f56542c53965f7ef95c21e5f37efffbdfe785eb9830f92c1a50dc8e3ed871c71dcb86583598d4fef8c73f565d21eba6c96ac530f11c880eba60c182d7c3c47c6978eeaab973e75e1326fe772c6504056bafa0085c9c16e96a8d3df7dc33ef3f569580f0559489f0b96fdfc4070cc8f6d9679fbace173e77999123472e1e3366cc2541d1fbd2a5975e7a4d1774158590a8d6382cf4d3c230d6b11e2eadd64fca9172a41c75ae1c45d25d6020ee0213c7286389dcfc6ab0234aad3c66e48ef763a42317fc06279f7c726e74117ecff88e60d087ef42ce7f1e71812cf39bf03b11c9846c4588dae1ba71381085c435e05444eef9cccf7dee732d0cb16870912a15e583e80b228ee2315c1be7e5f3f9eea18ff3bfc80ae7e41e130d3e1c11b5e44c395abae4a81218f140ad8bedb7dfbebc231191703ca6e1c8019c7038c188ac636c318ed75f7ffd3c5a0d789e7b7feaf049c1f9408b91288ccdcb2ebb2cdf09299d73906fea73e0cca080324e023e0b673a697e311a2e9549e477a79d76ca9d6cc8dbf8f1e35bd4ee00d21b91579c1cc71e7b6cfedcd5575f9d9f9b3987d771ac23433d997a65283cb7557c9ca63776069cffcf7ffe73fc97cf1dd39b6d21231d44ba101418bccbac9a10068d12c38ae537bff9cd7c55a7b87ac224c0c484d1c1c485724025fb6afcf0873fcc5795d29524de7bca29a7e42bc384c6a5a1724c22bc1e274814310c32c2b3510c53af3a303161f405e520bf0e263a5662c91d2fae02f35d999c30aac8556712e2f3a3b2c6248a371fe52ec22a57f48ca3d0a6931a707c4f53f64aa00d1c4cb85ef8bd9e0b93d5b4d45bce8ad2b3cf3e7b69b59cd96a10ba474121149248aae0e109fff297bfdc22ecb53536dc70c3e58262d010ce7d4967af30556070b8fe7d4bfdf442e8a3ab9664c54939528e94a3f6c9513dbbc030de8a30d6e3d822528046d5760c9922a42404e336973f1c09d43b611c4f9c3831bbf6da6b5b1c3b69d2a4dcf986f310438de81e64ec84134ec89d08c59074a28f908bc18307e7f28581c43571fe18055104c75c8cd2602c44038f8653038703204bc80df7118c2ed29f806b4be51e23bcbbeaa328473d673eaa04ce19c623f30035789011c60ee9283cc73d986322440270df265a8848019ce3e93d9db148ba1cc4f43a22286ebcf1c6ec89279ec89d6f8c799c3ea4296dbcf1c62db65e267268f4e8d1f978657ec39116e706d23448eb2bc2799863713ae03c40e690371c16ad6d4b1d21e2a15204452fa0960c95b7a76a2da2a7bd50883a6183de6e0319e920d205608430993019632c01ca11b04ac9f653e447eebdf7ded969a79d9687af31c9c4632278bfd395a8f4fce4d9e1c52e7aab01830c43058f298a25e766e2a3281fe173a961c5c482214301bb14261dbe032b1b28614141c89f273f1e85f3ab5ffd6aee398f0a1a0a1e8a2be1e64c8a28749c034f381324704d7165986be2f9b84a5d348ae20a776b3031733d619238a99b7eee21a10d0f93d57094862f7de94b4f873e5b9515a5b6287811c6027d4c38666a4cd33f1891b1bfdb4230ba973fecb0c3e6ffe217bf981e26d2e9e15affd50dfdc48a133feaaef453f8bdfed35adeb672a41c2947ed97a3b80b0cdf9d088122aded0213c7194e3e648eb186d14f68750b05331840c85aa5c8a334e5876b401e31f0d95e9634a5850b17e6a1e613264cc83f0ba308a71ef21277724106898e206c1bc7438c7488cebf34d201b9c1d08b6307471f1114c8d49c3973f21481b84a4b04068d73e298e1188c35ae2dee14c3b98814a91509a21cf56d39aa0529268cdde9d3a7e7110744f8309efef0873fe44eb7e27d98288018b5c73c4364008ebab7de7a2b4f87087d53aeefc0dc42e3bc140dc639c858c7214e5a11297dc81e3b1f51bf87790d6735d1453826703230bf31af300f31be495fc299c16e4a119c4bfcc6d17911ff32bfc5280d40f6392ff312f36f6a88f3fe4a73695be966396a21437cadd4d1d69914cebf8a4e07116995741534c2ffe90a28e1de69c8372badad111540cecfb67db5604535aeee72e3ac763c4a03f9bc4598e4e24a69119417269d540961028c79f7310790f75f72c925e563507c23184de977666bc3d80fe96e00ad8162c8768181eff784df3ef4c96a18c94ba2e045d87a2c09b1cb6185698f3df668cf24be62e93cfbf51031590745361ad2ca9172a41c758e1c6130d0303ae22e30409e777cccd8c5b0af3666ead905265d05aff07bb618e3a43f30f683519c1b571819a90184d1c56a314e070c5ca2888802421650ccd3488762645184e3711400ce0a8c3b9c0b14cb6395b9e8e0e478e48c718373211a8abc97eba967455f39eabb72540d9c04380c981f30e6890e204a8ef43cfa29d606c141405a42741847471f0e371c07fce5351ef3ded44188818ffc1269f4f0c30f97af3375f0112d11e7359c1ffccf3cc0ffc81fe398940dc6380ebe7aeb1d1541de9887b97fc4b997ef16e7c88ea087c951d993df51db6456a3708f69cc7a393a1d44ba896a8a51bda060a134d56b48908bc70a2e93589ce408efab15660e78aec9c9ad75bdac70b1fa1115199455de77c41147b4ff2635a06db7a92db6d8225720c304757207fe5cf54c74b1ac748b8e0a0af2b3afbefaeaca0f3ef860ddb9b345500a1a1a1a5a28f128ded417204f79495879e59589d57c57386f47ae2cd5d34f7c092c8e16a5cdc3753c120cf5753b428e58c564f587d54bf262a3d15e8428050c167677881065c0aa68a5f403c6354a24e1a531e73b0db7268415432cae7e721d182fc52aee288b54bc4e578b0a63a6c3e54e39528e2a8d67560f19638cc9b80b4c341650a8d310ed74ee21ad8950f15ad0d73810383eca64c9c0ccdf9f8261c575203b1865acb2c66afdcc57b7de7a6b0b03104721e74676711ccc9f3fbf45a403d75edce696ef1bbf1fd1467c16e7e671ba25244e089c0abc8e13a4e85ce0d87a530894a3a56b3e8a8622116a38a98806624ea17f30f471ae31be7efce31fe7a9478c5be601c608a9294405508f81d41f5224e238c3b98d0c44e86b1c11cc45c568ba4ae09c201d09b923da82a80a22214897228a0e070ba93329f3e6cdcbef03a45810bd80bc212f956a1a559aa790373e0707653e20832c2fa9dedb0972b4c43214c6c6e230467305a1b83b554793ee0ac36d59a78388740bdcc0c90367a2c0ebcd0a0f85e850d6789e89229d1cce3ffffcfcb9d460211f70a38d366a51d02b16fe89c42adf9b6db659d563984cd39b23064e9cb098a4087f2d16c9eb2c509c31c2bef39def9cd451e70c8664b509ea75269f30090d8e1353f87f7ef8ff96d0a60c1e3cf8864993262d38fef8e3f7193f7efcd4a080b439a495c281fcb6c53a05845d3209f3dbb435a4354cdc4f9f7beeb9cb846bdd3b2841d774413fd12f6f853e41b16b40c1abd44f41e96aea8849fae0830fce0d1614388c9d6a4e078a3112b61df3d3890a60acf25ec630ab2b54678fb052c45ec202e50000158b4944415471287a84a4b24a84b14471468a5ab28a941692e477437e62b441ea9c48f7e0ee8972a71cf55d39c278607bd67a7681c1019746d2c45d6030f659d9acc5873ef4a1fc2fc63b351a30ee391fc6545abb84cf25b501273ab2956e698b4c212fd55661792fbf1def654e8c69171470c50191ca0bf211cf93463ad0d24807b6afa5b123466bfd58dc194639723e02eebdcc3d146f8c5b18e334db64934d72a718910069d41ec638639286538b314c0d14eeffc5fa27dcf3195731f41e1d1019a93616f9ad48dbc311428a053585d01119ffcc75381ed2792682dce37ce3bd341c1d18d8518648392aa617e1e8e3ba894862270deab170afe1f3da5347a8a3e5a83d3214e6d759dcde780da751673a1d387fc2733a1d44a44bc123cd8d9e506b5adc5b9da2404c68185aac2455f24647d8de88e3d310ed485baa7c57ba360c3194528c26decbe489671dcf7d5b575b7b28af941415aa692dc38a4fe9393ae8d2f0fd6f090a4b8b99e2d4534fbdece8a38f7e2318b9d3c3dffef5ae30a1c891df9caea6a72b4c28f2e4f3f37bd5bbf21694c2a7c78d1bb74c5044f6ebec6ae1e13a179626efaca4e0d5eca78e80fea2f85ccc23254495fe4b1d6b80c184e38dcae0d463209796fe4439a25e04ce88a2a1830c10f21d149ffc33501051e8c26f9a9fbfa8702343b106450aef433e52a56d29943be5a89be4a82b7681615e8a21dc7c064608855301630ca7002bb4e49c733e522bf8cbb1ad45e0c5540a568c790fd78bec618c116a8e4c218fc57ceb98fb0e69a4030662711bc04a2057d47f88dc73cf3de55d639423e7a314c625e38afb6f74d2512fa89a031c47439437fa17039f315adc0e1988e0439e385ffcac4a6984e879f1f5526a423e57903a452d07c63c73034ec058a4b29a23bf528402724a0406ce371c17381b70b2f01d717613f547e41d4e07de8ff3a5e880ef8d7351f85e0f44a703df376eabdb19a4f79bc0033a1d44a44b610b1d5668631837558fd9368fc91e98882860570d2a83b3dd58542c2b912a52acae72538dab4f4c5471f594c9116f360a28de7342f7b83e0c378ec13bcd4a30e17b7d88e593896a7a68d706c5f51a56466abd69c28409338282b777f83bbddeaae1bffef5af5bac64131e494d00562563a579fe128ec9ea7e6b04857ceef8f1e31bbb42c12b297683dbda4fed81b1ca6a5b2c08072867e47153f02e858ae2f4255b98a178610845831f058e3c5c14a918918081c318675c6fbbedb6f9169a2895471e79643673e6ccb2c383f7a450488f55d394b81d21464baa842d6572a71c75b31c51b300c71b1170ac5e132acc7822243ceeea90ae4ec65d60805d6018ff959c03184538e5304a7034c462adb1682ae39674bf68e810f570fae9a7e7e7a6005fb5a88659b366e5f2c075e25c880e0b882bb538d3595de55a393e2575d8a5910e4570bc6040c57c749c27c813d74d8a624c2b4146494f694f7d04e5a86fce4718d838ae8942609ca17731deab39b7889c4b539b187fc5d4a6580b224dcb636c127d5458112fbf06fc3ec823910ba40b1139417d140aca3267b1730cc59799238bf586a2033e92d668a03825f30ee300e73e8ef338bf51e4923932952f9c96ed49b1e82932d4d4d4f4fb3096f68e4e9cd65294db03e74ffd3c3a1d44a4cb61c506cf35ca0f93195eeb082b4851b92b82824411a8741502051185331a466dadf28d5186c2c804c7e4ca04c724c44a1ae721e2a252e85e6f8430bbf0e7b6a0e85e188cd2dbdaba3282a21726f0616172bf3428f6036b297a28042821a992c76a3613395b5f11460f8c01940e56526a6ddf4408eb9831638650a8ab0b5694dad54f4b02ca0c860cb9b22938e68800623c9e74d249e5718db18572c4b8c57089ca112baeb1cf912d8c20a20730b070d4e1d0e3bd54b58fc5b76295f062b83972c00a6c71d50f2707c7e220894e87a549ee94a3ee95a3cede0586106e56378179859c766aa1444328e6fdc71c728c21b6cb8c4e3522289011e49290f4f8191862380b19dbd18180214388780c2d27d419671eb0f24eb450a5ba1418c7c856252330eea2813324de17ce38e38cb253909a2938f9714c76e62aa772d43be723e6221cbe2c00e1dc02b63e247528524c35203a203adb9025e613521a60ecd8b1e5fb7ed1794dda06bf5b25433eca2b8e211cef6c014d0412053fd1059127e64cc0d980f3018723f24b941c8e3d1cf0512e714832b790960bcc81cc39c85eac2344fa0de7261a90f300f3180b655c2be7aa16edd15b6428dc9b66bcf5d65b74dc00b60566ec17b71fee087024cd9c399330a286d253d3753a884897c1848fb2c836495179a4481d4a56dc0b99159e18b68da184d183228632c0f11855288be90499eecf0e6da9f28d32c279b9e9b26246a8257522501cb90e8ae16130c509a89772424343c39cc6c6c6e9ed5d190986ea95fbecb3cf8e13274ebcf65bdffad6a06a8a1edb5ac5950dc040a0d014bf25d12d28f271d5e1f5d75fcf8fc74028162d8c0a5e30c6d9777abfa953a7cee80dfdd416e8075621e91722009011949fa8e411c68d8380551d0c169465c256c9a94539643bb3087dc9ffe3c68d2b4739103e1ac3575945450ed3df2dfd9d52083dc5784ac39151fa701a62ac1443b39702b9538e7a801c75f62e3029181944e0b4465a7ba4de6d5de37c57cfb5156125bed68a2bd7905e472aab4b5ae55f395a3ae6a338ae70bcc422c5c8579ae6569489340a87e3706e47c7447c5fd1a18e23ac52a44e248df8c3e100cc2938fe8a6398df3d2d488cb3302db01c1d92d149510d3ea7e8c8e33afb924e3765ca94c7478c18715b9873879272c4f6a695d260da0b4ebef05b4487c31dd3a64d9ba3d34144ba0c267a42a9274f9e5c0e83e3c684471c03234e2a28004c38287251998b058098fcc8f5ab9582516f956f9831634676f8e187e7291b286678d531d2a858cc2489e246ce7b51c9ed4d849bfd0f3bf27c975d76d92d61d2daedacb3cebaf2a8a38e6a2c2a7a189984eea6ab87ec0fcf8a3d60b4320e7028a140a00cb26a414827bb22a47465ce6c47f753bda09cc5499ff18ed28b638ef14eff10e24d9fe178488d2cc05997460aa144a05ca521acfccfef8153807312aa4a8a45aa2416898e0656875258ed41a1637584d51fa22f9616b9538e7aae1cf5c09067bfaf72d42be7a38ac656618e68adce4e3d35316a391c5a9b2fdb72adedf99e7d5886502686f200a7030e9a8e8c7a2262f9eaabaf2e4739343434fca22fdc77fb6522d2eb205735e6dc12cd50ac5acc2a6fb1ba74aa6c61c8c42243d5268e787ea2227064f0b81816c76760ecc4a27d3c66f595dc3ebcdb847fb30ad59b1d0e9d45e8ff1b162e5cb8c78409131610a21721a40ee318a52d050333054753fa1b63c45e74d145e53057604509052f3c1cde1539b33dc58040d98d638ed5b75a06066397bcd4d828aac556644518dbe46ec66d04e34a51dcde2fca43ea5ce07f14129c2011a22c08f9262aa1581452b9538e449423911e2f2f44e8dcc663162a82dcb4ba8570bd10493971e2c4b7823c95a31ce6ce9d3bad2ff49b910e22bd8c5a5e6a5623d8be8f15d95a50619f1c5b72d159b52de6bcd65be59bc248aca8c62296383b28e445ae2e8a0a21e2f514945a9a15bd7df6d96797b163c75e7df4d147e72b4c545cafe5108ab01252ebb8b8a28482c7e72c2d7d4ada0139a431ad80bcd6629440f178528e52c86da5605deacc8b5bd492ce10b7d2c369405a077b8823734151281f8f030388b860c78b184e4b1e384e8a4aab54ca9d7224a21c89f40aa8d44c019955a8a944ed0d0a74b6670b4d1c0e13264c687ae28927625ed22b0d0d0d87dd76db6d8bfa84fde29811e97d90df8d7142c3d888c4940b8afd149d13d46d20cf92e278184e184c14c6db69a79df255516e9a115eabb4e24ae5ee74f5346ecb49e562bcbd1846185ba4776cb8e186b911460e2085bea43284b686fedb8515a6993367bed511e744c10bfd3e8810d6a549c123aa819405b6008cab6e14648c3b405482288138d663c329508c1ec2f83ff4d04373433fa6631069805383da116c434695ef585b25c2767454fae73a502870725443b9538e449423919e0f35169a9a9aa8869b3b0470fe932e496ac492c0fb4e3cf1c4b766cd9a15231c48abf85a9099bff7953ed3e920d2cbc098a2a277344ea8369cc20a68a5aaf5540cc730212c921554c090215583d5518caf4ac42adfb5602596155c8ae4b18d12b9e4f11a282675ebadb7fac3d5a7e82d6cafa217435883317ae0d214c2ca84cf5660a79c724a1e4540fe31ce878b2fbe38db65975daabe8fe8a0e8c08bad184a1c217a82a805aae233d6a94ecef88e7287138fe78b5050927c4f7605a0d06594bf5a2877ca91887224d27309639ab487c3a2e381c53bf48e2953a654dcc6b4121c476ae4e8d1a3d308078a431f3775ead4c97da9bf1a1c3222ede7e69b6f6e2a56faed6a30b23aa3884f3dfb2af7b4bd97d9ee69db6db7ed75f7b760b4eed0bf7fff2b468e1c3978830d36e8dfd6f7f7f610d6ee90a325d9e1216eb3d9d6d77a9bdc2947ca912847ca912847b5193e7cf8bee1cf390d0d0d2bc6e7d8b985484716fbd83e965425522f8878c4d1c056d83367cea42d5eb87061aa345085faa869d3a64dea6bbfa1351d44fa8a307752d5e07a8c9aa5adf2796781621614bdbdc68c1933fd98638e19b8d1461bd5ddb169912e4358eb6749b694ace554e808878372a71c89284722bd03221ef6dd77dfbb1a1a1ace652b4d9e23f5f1befbeecb5b6b2a45f2f80e6a38f4a5948a6a5f5444447a80a2f7e69b6fee3e7efcf83767ce9cf946bd0a1efb9e9b332ba21c892847225d0b351ec278672fed610d0d0de459b6a5f8e31da11df2d4534f6dd3571d0e3a1d44447a20e4d4a2e88d1b37ee8d7befbdf7d55ac73efcf0c373c78c1943b9e483cc9915518e449423916e733e4cc7f9d0bf7fff751a1a1a8e094f4d0f6d4e680b4a87f0f7f1d0908f51a1ad13deb305e9147d65978a6a985e2122d24315bd1123460c1b3f7e3c39b52f7dea539f7a471e40a92a78635353d37ea57da345443912518e44ba912953a6e05898506a9219e92022d263213475d1a245bb8d1d3bb6e19e7bee79297d2dad0aae8227a21c89284722d253d1e92022d283618529287a7b4e9830a1e1eebbef7e212a783167d6105611e548443912e9708687b656f23f190267d6f1be1beab4b1d70ded88568ee1f3960fed93a16d5a7a6e87d056d6e92022229da5e8f5ffd9cf7ef6b80a9e887224a21c89742a5b84f668f23f3517962d3d8ebbb93486b651d6ec9c888da2ab1f48feff51682b958ec771b063a9ad17dafac9ffb4430ad78073816d34d7086db5d273fb85f6bc4e071111e914452ffc197efbedb733f10c57c113518e449423914e6183d02e08ed23a1ed5c6a3805d62efd3d2eb455b3e6c29033437bb6e4a0a0bd9a3ce6f5ef86f642e9bc1497bc2e697392c74f97fe87754b9ff3fed0be99381c6071e9ef7a3a1d4444a4c321a7b6b1b17125b72113518e449423914e8128860d439b15da91a1dd9335ef36913a094e2e391a2257676f472bbc2f797c56c1de3e30b48db3e60806dac792c74447dc5a3aee91d2e73c16da4f4a0e09222a4e289d0f87c77125a7844e071111e958264d9a34df5e10518e449423914ea1b1e438c0a8bf226b4e65185e7222bc16daeea11d5078cf33d9db110b4f268f8982589c1c47e403751c5e2eb585c9e39daa5c0b9fb75ae95ca794ce47eac741a13dd15b3ad52d3345444444444444b28cdd59ce0fed7f43bb3d6b8e7cb8bef4fc75a563562dbce73d59b35382f7ac9935d766203a61d30ae7e7bd434b8fd74c1ea7c1005b85f6e5acd9f931a374ee41c9ebbfee6d9daad341444444444444a499c9a15d19daaea151c364546877965e23fae07fb2e6148bc8d8ac390d838888ff66cdc524af4bde93f274f6b6f362c7e4f11ec9317f0eed8fa19dd3573a54a7838888888888884833db67cdbb55602b53b0716ee21c600bcbe50ac7ff2eb489a17d3bb4b343bb29b4d3433ba98afdbd63e9f1dac9e3a792631654b9ae4d13fbfde3a1fd2b6b7670f478743a88888888888888341775c479403a0575148874200a21a64134168e275de22ba18dcededea5822293bfcc9ad33270489c97353b2e20dd16935d31a233e3bac235c090e4330f2fbd176708a916ecacc10e3237f5864ed5e920222222222222d25c38f2d2d01e4a9e7b3c6b763e00910e1b27ce0122214e4b8e8d9107ec40417148ea3cccadf2596fd4b8864343bbbff43fb5256697ce7346d69cc60177f6964ed5e920222222222222d2cc4385ff2f481ebf92bdbdb5e5f32587404a1ac9f05a2b8e81a36bbcf6abe4f1b3d9db5b74feb5d47a156e9929222222222222d27e16db05ef44a78388888888888888740a3a1d443a4290faf56b5abc58c7664f20fc0e8f66cd4576443912e5483912e5489423e548ba5ba6ec0291f6d3d8d8f8cccb2fbf6c47f4005e78e1050aed3c604f2847a21c2947a21c8972a41c49f7a3d341a403183870e01d2fbef8a21dd10378eaa9a7d8e2e8367b423912e5483912e5489423e548ba1f9d0e221dc082050bce9c3b77ee9b4d4d4d7646f73267debc796c4d74855da11c8972a41c897224ca917224dd8f4e07910e60cb2db7bc3b4c4c0f3df9e493764637327bf6ec9bc3eff0e4b6db6e7b97bda11c8972a41c897224ca917224dd8f4e07910e62c18205fbcf9933e7b5975e7ac9cee806e6cf9f7fd5bc79f37659bc78f131f6867224ca9172a41c2947a21c2947d233e86f1788740c93274f7eee80030eb8fbf9e79fdf6dc890218d83070fb653ba70629a356bd6ff3434341cb9dd76dbdd618f2847a21c2947ca917224ca9172243a1d44fa1c175d74d123fbefbfffbd4f3ffdf4eee146f9ea0a2bacb04cf86bc7741e7366cf9e7df99c39733ecfc43474e8d06bec12e5489423518e9423518e9423e9392835229dc08d37deb85ebf7efd260e183060c355575df5f155565965f5214386bc373c67e7b413f66b66fb24aa19535c885c3f42efb6df7efbd9f68e7224ca912847ca912847ca91e87410596ab8e9a69b36686868d82b3cdc3ab44f87d668afb49b4559f37ecdb7857685c5859423518e4439528e4439528e44444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444a497f3ff7b9a8174efd0c5d60000000049454e44ae426082, null);
COMMIT;

-- ----------------------------
--  Table structure for `act_ge_property`
-- ----------------------------
DROP TABLE IF EXISTS `act_ge_property`;
CREATE TABLE `act_ge_property` (
  `NAME_` varchar(64) COLLATE utf8_bin NOT NULL,
  `VALUE_` varchar(300) COLLATE utf8_bin DEFAULT NULL,
  `REV_` int(11) DEFAULT NULL,
  PRIMARY KEY (`NAME_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Records of `act_ge_property`
-- ----------------------------
BEGIN;
INSERT INTO `act_ge_property` VALUES ('next.dbid', '112501', '46'), ('schema.history', 'create(5.22.0.0)', '1'), ('schema.version', '5.22.0.0', '1');
COMMIT;

-- ----------------------------
--  Table structure for `act_hi_actinst`
-- ----------------------------
DROP TABLE IF EXISTS `act_hi_actinst`;
CREATE TABLE `act_hi_actinst` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `PROC_DEF_ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `EXECUTION_ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `ACT_ID_` varchar(255) COLLATE utf8_bin NOT NULL,
  `TASK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `CALL_PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `ACT_NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `ACT_TYPE_` varchar(255) COLLATE utf8_bin NOT NULL,
  `ASSIGNEE_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `START_TIME_` datetime(3) NOT NULL,
  `END_TIME_` datetime(3) DEFAULT NULL,
  `DURATION_` bigint(20) DEFAULT NULL,
  `TENANT_ID_` varchar(255) COLLATE utf8_bin DEFAULT '',
  PRIMARY KEY (`ID_`),
  KEY `ACT_IDX_HI_ACT_INST_START` (`START_TIME_`),
  KEY `ACT_IDX_HI_ACT_INST_END` (`END_TIME_`),
  KEY `ACT_IDX_HI_ACT_INST_PROCINST` (`PROC_INST_ID_`,`ACT_ID_`),
  KEY `ACT_IDX_HI_ACT_INST_EXEC` (`EXECUTION_ID_`,`ACT_ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_hi_attachment`
-- ----------------------------
DROP TABLE IF EXISTS `act_hi_attachment`;
CREATE TABLE `act_hi_attachment` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `USER_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `DESCRIPTION_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `TYPE_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `TASK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `URL_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `CONTENT_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `TIME_` datetime(3) DEFAULT NULL,
  PRIMARY KEY (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_hi_comment`
-- ----------------------------
DROP TABLE IF EXISTS `act_hi_comment`;
CREATE TABLE `act_hi_comment` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `TYPE_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `TIME_` datetime(3) NOT NULL,
  `USER_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `TASK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `ACTION_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `MESSAGE_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `FULL_MSG_` longblob,
  PRIMARY KEY (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_hi_detail`
-- ----------------------------
DROP TABLE IF EXISTS `act_hi_detail`;
CREATE TABLE `act_hi_detail` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `TYPE_` varchar(255) COLLATE utf8_bin NOT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `EXECUTION_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `TASK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `ACT_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `NAME_` varchar(255) COLLATE utf8_bin NOT NULL,
  `VAR_TYPE_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `REV_` int(11) DEFAULT NULL,
  `TIME_` datetime(3) NOT NULL,
  `BYTEARRAY_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `DOUBLE_` double DEFAULT NULL,
  `LONG_` bigint(20) DEFAULT NULL,
  `TEXT_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `TEXT2_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  PRIMARY KEY (`ID_`),
  KEY `ACT_IDX_HI_DETAIL_PROC_INST` (`PROC_INST_ID_`),
  KEY `ACT_IDX_HI_DETAIL_ACT_INST` (`ACT_INST_ID_`),
  KEY `ACT_IDX_HI_DETAIL_TIME` (`TIME_`),
  KEY `ACT_IDX_HI_DETAIL_NAME` (`NAME_`),
  KEY `ACT_IDX_HI_DETAIL_TASK_ID` (`TASK_ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_hi_identitylink`
-- ----------------------------
DROP TABLE IF EXISTS `act_hi_identitylink`;
CREATE TABLE `act_hi_identitylink` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `GROUP_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `TYPE_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `USER_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `TASK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  PRIMARY KEY (`ID_`),
  KEY `ACT_IDX_HI_IDENT_LNK_USER` (`USER_ID_`),
  KEY `ACT_IDX_HI_IDENT_LNK_TASK` (`TASK_ID_`),
  KEY `ACT_IDX_HI_IDENT_LNK_PROCINST` (`PROC_INST_ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_hi_procinst`
-- ----------------------------
DROP TABLE IF EXISTS `act_hi_procinst`;
CREATE TABLE `act_hi_procinst` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `BUSINESS_KEY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `PROC_DEF_ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `START_TIME_` datetime(3) NOT NULL,
  `END_TIME_` datetime(3) DEFAULT NULL,
  `DURATION_` bigint(20) DEFAULT NULL,
  `START_USER_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `START_ACT_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `END_ACT_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `SUPER_PROCESS_INSTANCE_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `DELETE_REASON_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `TENANT_ID_` varchar(255) COLLATE utf8_bin DEFAULT '',
  `NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  PRIMARY KEY (`ID_`),
  UNIQUE KEY `PROC_INST_ID_` (`PROC_INST_ID_`),
  KEY `ACT_IDX_HI_PRO_INST_END` (`END_TIME_`),
  KEY `ACT_IDX_HI_PRO_I_BUSKEY` (`BUSINESS_KEY_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_hi_taskinst`
-- ----------------------------
DROP TABLE IF EXISTS `act_hi_taskinst`;
CREATE TABLE `act_hi_taskinst` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `PROC_DEF_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `TASK_DEF_KEY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `EXECUTION_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `PARENT_TASK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `DESCRIPTION_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `OWNER_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `ASSIGNEE_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `START_TIME_` datetime(3) NOT NULL,
  `CLAIM_TIME_` datetime(3) DEFAULT NULL,
  `END_TIME_` datetime(3) DEFAULT NULL,
  `DURATION_` bigint(20) DEFAULT NULL,
  `DELETE_REASON_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `PRIORITY_` int(11) DEFAULT NULL,
  `DUE_DATE_` datetime(3) DEFAULT NULL,
  `FORM_KEY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `CATEGORY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `TENANT_ID_` varchar(255) COLLATE utf8_bin DEFAULT '',
  PRIMARY KEY (`ID_`),
  KEY `ACT_IDX_HI_TASK_INST_PROCINST` (`PROC_INST_ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_hi_varinst`
-- ----------------------------
DROP TABLE IF EXISTS `act_hi_varinst`;
CREATE TABLE `act_hi_varinst` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `EXECUTION_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `TASK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `NAME_` varchar(255) COLLATE utf8_bin NOT NULL,
  `VAR_TYPE_` varchar(100) COLLATE utf8_bin DEFAULT NULL,
  `REV_` int(11) DEFAULT NULL,
  `BYTEARRAY_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `DOUBLE_` double DEFAULT NULL,
  `LONG_` bigint(20) DEFAULT NULL,
  `TEXT_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `TEXT2_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `CREATE_TIME_` datetime(3) DEFAULT NULL,
  `LAST_UPDATED_TIME_` datetime(3) DEFAULT NULL,
  PRIMARY KEY (`ID_`),
  KEY `ACT_IDX_HI_PROCVAR_PROC_INST` (`PROC_INST_ID_`),
  KEY `ACT_IDX_HI_PROCVAR_NAME_TYPE` (`NAME_`,`VAR_TYPE_`),
  KEY `ACT_IDX_HI_PROCVAR_TASK_ID` (`TASK_ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_id_group`
-- ----------------------------
DROP TABLE IF EXISTS `act_id_group`;
CREATE TABLE `act_id_group` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `TYPE_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  PRIMARY KEY (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_id_info`
-- ----------------------------
DROP TABLE IF EXISTS `act_id_info`;
CREATE TABLE `act_id_info` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `USER_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `TYPE_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `KEY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `VALUE_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `PASSWORD_` longblob,
  `PARENT_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  PRIMARY KEY (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_id_membership`
-- ----------------------------
DROP TABLE IF EXISTS `act_id_membership`;
CREATE TABLE `act_id_membership` (
  `USER_ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `GROUP_ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  PRIMARY KEY (`USER_ID_`,`GROUP_ID_`),
  KEY `ACT_FK_MEMB_GROUP` (`GROUP_ID_`),
  CONSTRAINT `ACT_FK_MEMB_GROUP` FOREIGN KEY (`GROUP_ID_`) REFERENCES `act_id_group` (`ID_`),
  CONSTRAINT `ACT_FK_MEMB_USER` FOREIGN KEY (`USER_ID_`) REFERENCES `act_id_user` (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_id_user`
-- ----------------------------
DROP TABLE IF EXISTS `act_id_user`;
CREATE TABLE `act_id_user` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `FIRST_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `LAST_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `EMAIL_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `PWD_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `PICTURE_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  PRIMARY KEY (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_procdef_info`
-- ----------------------------
DROP TABLE IF EXISTS `act_procdef_info`;
CREATE TABLE `act_procdef_info` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `PROC_DEF_ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `INFO_JSON_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  PRIMARY KEY (`ID_`),
  UNIQUE KEY `ACT_UNIQ_INFO_PROCDEF` (`PROC_DEF_ID_`),
  KEY `ACT_IDX_INFO_PROCDEF` (`PROC_DEF_ID_`),
  KEY `ACT_FK_INFO_JSON_BA` (`INFO_JSON_ID_`),
  CONSTRAINT `ACT_FK_INFO_JSON_BA` FOREIGN KEY (`INFO_JSON_ID_`) REFERENCES `act_ge_bytearray` (`ID_`),
  CONSTRAINT `ACT_FK_INFO_PROCDEF` FOREIGN KEY (`PROC_DEF_ID_`) REFERENCES `act_re_procdef` (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_re_deployment`
-- ----------------------------
DROP TABLE IF EXISTS `act_re_deployment`;
CREATE TABLE `act_re_deployment` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `CATEGORY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `TENANT_ID_` varchar(255) COLLATE utf8_bin DEFAULT '',
  `DEPLOY_TIME_` timestamp(3) NULL DEFAULT NULL,
  PRIMARY KEY (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Records of `act_re_deployment`
-- ----------------------------
BEGIN;
INSERT INTO `act_re_deployment` VALUES ('110001', '流程审批测试流程', null, '', '2017-12-04 09:53:06.088');
COMMIT;

-- ----------------------------
--  Table structure for `act_re_model`
-- ----------------------------
DROP TABLE IF EXISTS `act_re_model`;
CREATE TABLE `act_re_model` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `KEY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `CATEGORY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `CREATE_TIME_` timestamp(3) NULL DEFAULT NULL,
  `LAST_UPDATE_TIME_` timestamp(3) NULL DEFAULT NULL,
  `VERSION_` int(11) DEFAULT NULL,
  `META_INFO_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `DEPLOYMENT_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `EDITOR_SOURCE_VALUE_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `EDITOR_SOURCE_EXTRA_VALUE_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `TENANT_ID_` varchar(255) COLLATE utf8_bin DEFAULT '',
  PRIMARY KEY (`ID_`),
  KEY `ACT_FK_MODEL_SOURCE` (`EDITOR_SOURCE_VALUE_ID_`),
  KEY `ACT_FK_MODEL_SOURCE_EXTRA` (`EDITOR_SOURCE_EXTRA_VALUE_ID_`),
  KEY `ACT_FK_MODEL_DEPLOYMENT` (`DEPLOYMENT_ID_`),
  CONSTRAINT `ACT_FK_MODEL_DEPLOYMENT` FOREIGN KEY (`DEPLOYMENT_ID_`) REFERENCES `act_re_deployment` (`ID_`),
  CONSTRAINT `ACT_FK_MODEL_SOURCE` FOREIGN KEY (`EDITOR_SOURCE_VALUE_ID_`) REFERENCES `act_ge_bytearray` (`ID_`),
  CONSTRAINT `ACT_FK_MODEL_SOURCE_EXTRA` FOREIGN KEY (`EDITOR_SOURCE_EXTRA_VALUE_ID_`) REFERENCES `act_ge_bytearray` (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Records of `act_re_model`
-- ----------------------------
BEGIN;
INSERT INTO `act_re_model` VALUES ('57501', '28', '流程审批测试流程', 'test_audit02', null, '2017-11-12 08:42:12.515', '2017-12-04 09:53:07.270', '1', '{\"name\":\"流程审批测试流程\",\"revision\":1,\"description\":\"\"}', '110001', '57502', '62501', '');
COMMIT;

-- ----------------------------
--  Table structure for `act_re_procdef`
-- ----------------------------
DROP TABLE IF EXISTS `act_re_procdef`;
CREATE TABLE `act_re_procdef` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `CATEGORY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `KEY_` varchar(255) COLLATE utf8_bin NOT NULL,
  `VERSION_` int(11) NOT NULL,
  `DEPLOYMENT_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `RESOURCE_NAME_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `DGRM_RESOURCE_NAME_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `DESCRIPTION_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `HAS_START_FORM_KEY_` tinyint(4) DEFAULT NULL,
  `HAS_GRAPHICAL_NOTATION_` tinyint(4) DEFAULT NULL,
  `SUSPENSION_STATE_` int(11) DEFAULT NULL,
  `TENANT_ID_` varchar(255) COLLATE utf8_bin DEFAULT '',
  PRIMARY KEY (`ID_`),
  UNIQUE KEY `ACT_UNIQ_PROCDEF` (`KEY_`,`VERSION_`,`TENANT_ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Records of `act_re_procdef`
-- ----------------------------
BEGIN;
INSERT INTO `act_re_procdef` VALUES ('salary:1:110004', '1', 'http://www.activiti.org/test', '流程审批测试流程', 'salary', '1', '110001', '流程审批测试流程.bpmn20.xml', '流程审批测试流程.salary.png', null, '1', '1', '1', '');
COMMIT;

-- ----------------------------
--  Table structure for `act_ru_event_subscr`
-- ----------------------------
DROP TABLE IF EXISTS `act_ru_event_subscr`;
CREATE TABLE `act_ru_event_subscr` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `EVENT_TYPE_` varchar(255) COLLATE utf8_bin NOT NULL,
  `EVENT_NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `EXECUTION_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `ACTIVITY_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `CONFIGURATION_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `CREATED_` timestamp(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3),
  `PROC_DEF_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `TENANT_ID_` varchar(255) COLLATE utf8_bin DEFAULT '',
  PRIMARY KEY (`ID_`),
  KEY `ACT_IDX_EVENT_SUBSCR_CONFIG_` (`CONFIGURATION_`),
  KEY `ACT_FK_EVENT_EXEC` (`EXECUTION_ID_`),
  CONSTRAINT `ACT_FK_EVENT_EXEC` FOREIGN KEY (`EXECUTION_ID_`) REFERENCES `act_ru_execution` (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_ru_execution`
-- ----------------------------
DROP TABLE IF EXISTS `act_ru_execution`;
CREATE TABLE `act_ru_execution` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `BUSINESS_KEY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `PARENT_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_DEF_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `SUPER_EXEC_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `ACT_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `IS_ACTIVE_` tinyint(4) DEFAULT NULL,
  `IS_CONCURRENT_` tinyint(4) DEFAULT NULL,
  `IS_SCOPE_` tinyint(4) DEFAULT NULL,
  `IS_EVENT_SCOPE_` tinyint(4) DEFAULT NULL,
  `SUSPENSION_STATE_` int(11) DEFAULT NULL,
  `CACHED_ENT_STATE_` int(11) DEFAULT NULL,
  `TENANT_ID_` varchar(255) COLLATE utf8_bin DEFAULT '',
  `NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `LOCK_TIME_` timestamp(3) NULL DEFAULT NULL,
  PRIMARY KEY (`ID_`),
  KEY `ACT_IDX_EXEC_BUSKEY` (`BUSINESS_KEY_`),
  KEY `ACT_FK_EXE_PROCINST` (`PROC_INST_ID_`),
  KEY `ACT_FK_EXE_PARENT` (`PARENT_ID_`),
  KEY `ACT_FK_EXE_SUPER` (`SUPER_EXEC_`),
  KEY `ACT_FK_EXE_PROCDEF` (`PROC_DEF_ID_`),
  CONSTRAINT `ACT_FK_EXE_PARENT` FOREIGN KEY (`PARENT_ID_`) REFERENCES `act_ru_execution` (`ID_`),
  CONSTRAINT `ACT_FK_EXE_PROCDEF` FOREIGN KEY (`PROC_DEF_ID_`) REFERENCES `act_re_procdef` (`ID_`),
  CONSTRAINT `ACT_FK_EXE_PROCINST` FOREIGN KEY (`PROC_INST_ID_`) REFERENCES `act_ru_execution` (`ID_`) ON DELETE CASCADE ON UPDATE CASCADE,
  CONSTRAINT `ACT_FK_EXE_SUPER` FOREIGN KEY (`SUPER_EXEC_`) REFERENCES `act_ru_execution` (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_ru_identitylink`
-- ----------------------------
DROP TABLE IF EXISTS `act_ru_identitylink`;
CREATE TABLE `act_ru_identitylink` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `GROUP_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `TYPE_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `USER_ID_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `TASK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_DEF_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  PRIMARY KEY (`ID_`),
  KEY `ACT_IDX_IDENT_LNK_USER` (`USER_ID_`),
  KEY `ACT_IDX_IDENT_LNK_GROUP` (`GROUP_ID_`),
  KEY `ACT_IDX_ATHRZ_PROCEDEF` (`PROC_DEF_ID_`),
  KEY `ACT_FK_TSKASS_TASK` (`TASK_ID_`),
  KEY `ACT_FK_IDL_PROCINST` (`PROC_INST_ID_`),
  CONSTRAINT `ACT_FK_ATHRZ_PROCEDEF` FOREIGN KEY (`PROC_DEF_ID_`) REFERENCES `act_re_procdef` (`ID_`),
  CONSTRAINT `ACT_FK_IDL_PROCINST` FOREIGN KEY (`PROC_INST_ID_`) REFERENCES `act_ru_execution` (`ID_`),
  CONSTRAINT `ACT_FK_TSKASS_TASK` FOREIGN KEY (`TASK_ID_`) REFERENCES `act_ru_task` (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_ru_job`
-- ----------------------------
DROP TABLE IF EXISTS `act_ru_job`;
CREATE TABLE `act_ru_job` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `TYPE_` varchar(255) COLLATE utf8_bin NOT NULL,
  `LOCK_EXP_TIME_` timestamp(3) NULL DEFAULT NULL,
  `LOCK_OWNER_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `EXCLUSIVE_` tinyint(1) DEFAULT NULL,
  `EXECUTION_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROCESS_INSTANCE_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_DEF_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `RETRIES_` int(11) DEFAULT NULL,
  `EXCEPTION_STACK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `EXCEPTION_MSG_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `DUEDATE_` timestamp(3) NULL DEFAULT NULL,
  `REPEAT_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `HANDLER_TYPE_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `HANDLER_CFG_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `TENANT_ID_` varchar(255) COLLATE utf8_bin DEFAULT '',
  PRIMARY KEY (`ID_`),
  KEY `ACT_FK_JOB_EXCEPTION` (`EXCEPTION_STACK_ID_`),
  CONSTRAINT `ACT_FK_JOB_EXCEPTION` FOREIGN KEY (`EXCEPTION_STACK_ID_`) REFERENCES `act_ge_bytearray` (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_ru_task`
-- ----------------------------
DROP TABLE IF EXISTS `act_ru_task`;
CREATE TABLE `act_ru_task` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `EXECUTION_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_DEF_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `NAME_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `PARENT_TASK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `DESCRIPTION_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `TASK_DEF_KEY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `OWNER_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `ASSIGNEE_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `DELEGATION_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PRIORITY_` int(11) DEFAULT NULL,
  `CREATE_TIME_` timestamp(3) NULL DEFAULT NULL,
  `DUE_DATE_` datetime(3) DEFAULT NULL,
  `CATEGORY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `SUSPENSION_STATE_` int(11) DEFAULT NULL,
  `TENANT_ID_` varchar(255) COLLATE utf8_bin DEFAULT '',
  `FORM_KEY_` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  PRIMARY KEY (`ID_`),
  KEY `ACT_IDX_TASK_CREATE` (`CREATE_TIME_`),
  KEY `ACT_FK_TASK_EXE` (`EXECUTION_ID_`),
  KEY `ACT_FK_TASK_PROCINST` (`PROC_INST_ID_`),
  KEY `ACT_FK_TASK_PROCDEF` (`PROC_DEF_ID_`),
  CONSTRAINT `ACT_FK_TASK_EXE` FOREIGN KEY (`EXECUTION_ID_`) REFERENCES `act_ru_execution` (`ID_`),
  CONSTRAINT `ACT_FK_TASK_PROCDEF` FOREIGN KEY (`PROC_DEF_ID_`) REFERENCES `act_re_procdef` (`ID_`),
  CONSTRAINT `ACT_FK_TASK_PROCINST` FOREIGN KEY (`PROC_INST_ID_`) REFERENCES `act_ru_execution` (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `act_ru_variable`
-- ----------------------------
DROP TABLE IF EXISTS `act_ru_variable`;
CREATE TABLE `act_ru_variable` (
  `ID_` varchar(64) COLLATE utf8_bin NOT NULL,
  `REV_` int(11) DEFAULT NULL,
  `TYPE_` varchar(255) COLLATE utf8_bin NOT NULL,
  `NAME_` varchar(255) COLLATE utf8_bin NOT NULL,
  `EXECUTION_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `PROC_INST_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `TASK_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `BYTEARRAY_ID_` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `DOUBLE_` double DEFAULT NULL,
  `LONG_` bigint(20) DEFAULT NULL,
  `TEXT_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  `TEXT2_` varchar(4000) COLLATE utf8_bin DEFAULT NULL,
  PRIMARY KEY (`ID_`),
  KEY `ACT_IDX_VARIABLE_TASK_ID` (`TASK_ID_`),
  KEY `ACT_FK_VAR_EXE` (`EXECUTION_ID_`),
  KEY `ACT_FK_VAR_PROCINST` (`PROC_INST_ID_`),
  KEY `ACT_FK_VAR_BYTEARRAY` (`BYTEARRAY_ID_`),
  CONSTRAINT `ACT_FK_VAR_BYTEARRAY` FOREIGN KEY (`BYTEARRAY_ID_`) REFERENCES `act_ge_bytearray` (`ID_`),
  CONSTRAINT `ACT_FK_VAR_EXE` FOREIGN KEY (`EXECUTION_ID_`) REFERENCES `act_ru_execution` (`ID_`),
  CONSTRAINT `ACT_FK_VAR_PROCINST` FOREIGN KEY (`PROC_INST_ID_`) REFERENCES `act_ru_execution` (`ID_`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
--  Table structure for `app_company`
-- ----------------------------
DROP TABLE IF EXISTS `app_company`;
CREATE TABLE `app_company` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `name` varchar(100) DEFAULT NULL,
  `lon` varchar(20) DEFAULT NULL,
  `lat` varchar(20) DEFAULT NULL,
  `sign_in_time` varchar(20) DEFAULT NULL,
  `sign_out_time` varchar(20) DEFAULT NULL,
  `sign_distance` double DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

-- ----------------------------
--  Records of `app_company`
-- ----------------------------
BEGIN;
INSERT INTO `app_company` VALUES ('1', '秦天网络', '113.37', '22.94', '09:00', '23:00', '2000');
COMMIT;

-- ----------------------------
--  Table structure for `app_out_work`
-- ----------------------------
DROP TABLE IF EXISTS `app_out_work`;
CREATE TABLE `app_out_work` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `user_id` bigint(20) DEFAULT NULL,
  `from_time` datetime DEFAULT NULL,
  `end_time` datetime DEFAULT NULL,
  `lon` varchar(20) DEFAULT NULL,
  `lat` varchar(20) DEFAULT NULL,
  `sign_distance` double DEFAULT NULL,
  `real_name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;

-- ----------------------------
--  Records of `app_out_work`
-- ----------------------------
BEGIN;
INSERT INTO `app_out_work` VALUES ('8', '2', '2018-03-30 12:00:00', '2018-04-05 12:00:00', '15', '15', '12', '张三'), ('9', '7', '2018-03-28 00:00:00', '2018-04-28 00:00:00', '113.37', '22.93', '2000', 'Aron');
COMMIT;

-- ----------------------------
--  Table structure for `app_sign`
-- ----------------------------
DROP TABLE IF EXISTS `app_sign`;
CREATE TABLE `app_sign` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `user_id` bigint(20) DEFAULT NULL,
  `create_time` datetime DEFAULT NULL,
  `lat` varchar(20) DEFAULT NULL,
  `lon` varchar(20) DEFAULT NULL,
  `address_detail` varchar(100) DEFAULT NULL,
  `sign_type` int(8) DEFAULT NULL COMMENT '签到类型，1签到，2签退',
  `sign_status` int(8) DEFAULT NULL COMMENT '1准时，2迟到',
  `remark` varchar(100) DEFAULT NULL,
  `real_name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=77 DEFAULT CHARSET=utf8;

-- ----------------------------
--  Records of `app_sign`
-- ----------------------------
BEGIN;
INSERT INTO `app_sign` VALUES ('36', '5', '2018-03-20 08:50:00', '12.5', '12.5', '', '1', '1', '1', '李四'), ('37', '5', '2018-03-20 18:50:00', '12.5', '12.5', '', '2', '1', '1', '李四'), ('38', '5', '2018-03-21 08:50:00', '12.5', '12.5', '', '1', '2', '1', '李四'), ('39', '5', '2018-03-21 18:50:00', '12.5', '12.5', '', '2', '1', '1', '李四'), ('40', '5', '2018-03-22 08:50:00', '12.5', '12.5', '', '1', '2', '1', '李四'), ('41', '5', '2018-03-22 18:50:00', '12.5', '12.5', '', '2', '1', '1', '李四'), ('42', '5', '2018-03-23 08:50:00', '12.5', '12.5', '', '1', '1', '1', '李四'), ('43', '5', '2018-03-23 18:50:00', '12.5', '12.5', '', '2', '1', '1', '李四'), ('44', '5', '2018-03-24 08:50:00', '12.5', '12.5', '', '1', '2', '1', '李四'), ('45', '5', '2018-03-24 18:50:00', '12.5', '12.5', '', '2', '1', '1', '李四'), ('46', '5', '2018-03-25 08:50:00', '12.5', '12.5', '', '1', '1', '1', '李四'), ('47', '5', '2018-03-25 18:50:00', '12.5', '12.5', '', '2', '2', '1', '李四'), ('48', '5', '2018-03-26 08:50:00', '12.5', '12.5', '', '1', '1', '1', '李四'), ('49', '5', '2018-03-26 18:50:00', '12.5', '12.5', '', '2', '1', '1', '李四'), ('50', '5', '2018-03-27 08:50:00', '12.5', '12.5', '', '1', '2', '1', '李四'), ('51', '5', '2018-03-27 18:50:00', '12.5', '12.5', '', '2', '1', '1', '李四'), ('55', '4', '2018-04-01 03:51:07', '22.94', '113.38', null, '1', '1', '1', '李四'), ('60', '5', '2018-04-01 05:05:01', '22.94', '113.38', null, '1', '1', '1', '李四'), ('62', '6', '2018-04-01 05:27:21', '22.94', '113.38', null, '1', '1', '1', 'wangwu'), ('71', '6', '2018-04-01 21:16:41', null, null, null, '2', '3', '请假', 'wangwu'), ('76', '7', '2018-04-01 22:06:14', null, null, null, '2', '3', '请假', 'Aron');
COMMIT;

-- ----------------------------
--  Table structure for `app_user`
-- ----------------------------
DROP TABLE IF EXISTS `app_user`;
CREATE TABLE `app_user` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `real_name` varchar(20) DEFAULT NULL,
  `mobile` varchar(20) DEFAULT NULL,
  `create_time` datetime DEFAULT NULL,
  `last_login_time` datetime DEFAULT NULL,
  `uname` varchar(20) DEFAULT NULL,
  `passwd` varchar(100) DEFAULT NULL,
  `openid` varchar(100) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

-- ----------------------------
--  Records of `app_user`
-- ----------------------------
BEGIN;
INSERT INTO `app_user` VALUES ('2', '张三', '15277778888', '2017-01-01 12:12:12', '2017-01-01 12:12:12', 'zhangSan', 'zhangSan', '1'), ('5', '李四', '15278792752', '2018-03-27 23:16:53', null, 'lisi', 'lisi', ''), ('6', 'wangwu', '15277778888', '2018-04-01 05:16:16', null, 'wangwu', 'wangwu', ''), ('7', 'Aron', '15277779999', '2018-04-01 21:59:50', null, 'Aron', 'Aron', 'oy03r0BhZIURZGTNfHZfwijCXkYQ');
COMMIT;

-- ----------------------------
--  Table structure for `blog_content`
-- ----------------------------
DROP TABLE IF EXISTS `blog_content`;
CREATE TABLE `blog_content` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `title` varchar(255) DEFAULT NULL COMMENT '标题',
  `slug` varchar(255) DEFAULT NULL,
  `created` bigint(20) DEFAULT NULL COMMENT '创建人id',
  `modified` bigint(20) DEFAULT NULL COMMENT '最近修改人id',
  `content` text COMMENT '内容',
  `type` varchar(16) DEFAULT NULL COMMENT '类型',
  `tags` varchar(200) DEFAULT NULL COMMENT '标签',
  `categories` varchar(200) DEFAULT NULL COMMENT '分类',
  `hits` int(5) DEFAULT NULL,
  `comments_num` int(5) DEFAULT '0' COMMENT '评论数量',
  `allow_comment` int(1) DEFAULT '0' COMMENT '开启评论',
  `allow_ping` int(1) DEFAULT '0' COMMENT '允许ping',
  `allow_feed` int(1) DEFAULT '0' COMMENT '允许反馈',
  `status` int(1) DEFAULT NULL COMMENT '状态',
  `author` varchar(100) DEFAULT NULL COMMENT '作者',
  `gtm_create` datetime DEFAULT NULL COMMENT '创建时间',
  `gtm_modified` datetime DEFAULT NULL COMMENT '修改时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=133 DEFAULT CHARSET=utf8 COMMENT='文章内容';

-- ----------------------------
--  Records of `blog_content`
-- ----------------------------
BEGIN;
INSERT INTO `blog_content` VALUES ('75', '基于 Springboot 和 Mybatis 的后台管理系统 BootDo', null, null, null, '项目介绍<ul style=\"margin-right: 0px; margin-bottom: 0px; margin-left: 0px; padding: 0px 30px; list-style-position: initial; list-style-image: initial; color: rgb(17, 17, 17); font-family: &quot;PingFang SC&quot;, &quot;Helvetica Neue&quot;, &quot;Microsoft YaHei UI&quot;, &quot;Microsoft YaHei&quot;, &quot;Noto Sans CJK SC&quot;, Sathu, EucrosiaUPC, sans-serif; font-size: 16px;\"><li><p>面向学习型的开源框架，简洁高效，减少过渡封装，展现技术本质</p></li><li><p>Springboot作为基础框架，使用mybatis作为持久层框架</p></li><li><p>使用官方推荐的thymeleaf做为模板引擎，shiro作为安全框架,主流技术，“一网打尽”</p></li><li><p>基于注解的sql写法，零XML，极简配置，一键前后台代码生成</p></li></ul><p style=\"color: rgb(17, 17, 17); font-family: &quot;PingFang SC&quot;, &quot;Helvetica Neue&quot;, &quot;Microsoft YaHei UI&quot;, &quot;Microsoft YaHei&quot;, &quot;Noto Sans CJK SC&quot;, Sathu, EucrosiaUPC, sans-serif; font-size: 16px;\"><span style=\"font-weight: bolder;\">演示地址</span>&nbsp;<a href=\"http://47.93.239.129/\" style=\"outline: 0px; color: rgb(68, 102, 187);\" rel=\"nofollow\">http://47.93.239.129</a></p>功能简介<p style=\"color: rgb(17, 17, 17); font-family: &quot;PingFang SC&quot;, &quot;Helvetica Neue&quot;, &quot;Microsoft YaHei UI&quot;, &quot;Microsoft YaHei&quot;, &quot;Noto Sans CJK SC&quot;, Sathu, EucrosiaUPC, sans-serif; font-size: 16px;\">1. 用户管理<br>2. 角色管理<br>3. 部门管理<br>4. 菜单管理<br>5. 系统日志<br>6. 代码生成<br>7. 内容管理</p>所用框架<p style=\"color: rgb(17, 17, 17); font-family: &quot;PingFang SC&quot;, &quot;Helvetica Neue&quot;, &quot;Microsoft YaHei UI&quot;, &quot;Microsoft YaHei&quot;, &quot;Noto Sans CJK SC&quot;, Sathu, EucrosiaUPC, sans-serif; font-size: 16px;\"><span style=\"font-weight: bolder;\">前端</span><br>1. Bootstrap<br>2. jQuery<br>3. bootstrap-table<br>4. layer<br>5. jsTree&nbsp;<br>6. summernote<br>7. jquery-validate<br>8. jquery-treegrid</p><p style=\"color: rgb(17, 17, 17); font-family: &quot;PingFang SC&quot;, &quot;Helvetica Neue&quot;, &quot;Microsoft YaHei UI&quot;, &quot;Microsoft YaHei&quot;, &quot;Noto Sans CJK SC&quot;, Sathu, EucrosiaUPC, sans-serif; font-size: 16px;\"><span style=\"font-weight: bolder;\">后端</span><br>1. SpringBoot&nbsp;<br>2. MyBatis<br>3. Thymeleaf<br>4. Shiro<br>5. druid</p><p style=\"color: rgb(17, 17, 17); font-family: &quot;PingFang SC&quot;, &quot;Helvetica Neue&quot;, &quot;Microsoft YaHei UI&quot;, &quot;Microsoft YaHei&quot;, &quot;Noto Sans CJK SC&quot;, Sathu, EucrosiaUPC, sans-serif; font-size: 16px;\"><span style=\"font-weight: bolder;\">项目截图</span></p><p style=\"color: rgb(17, 17, 17); font-family: &quot;PingFang SC&quot;, &quot;Helvetica Neue&quot;, &quot;Microsoft YaHei UI&quot;, &quot;Microsoft YaHei&quot;, &quot;Noto Sans CJK SC&quot;, Sathu, EucrosiaUPC, sans-serif; font-size: 16px;\"><img height=\"400\" src=\"https://static.oschina.net/uploads/space/2017/0912/182421_5LaN_3244087.png\" width=\"650\" style=\"border-width: initial; border-style: none; outline: 0px; width: 882px; max-width: -webkit-fit-content; height: auto;\"></p>', 'article', null, null, null, null, '0', '0', '1', '1', 'bootdo', '2018-01-02 23:50:23', '2018-01-02 23:50:23'), ('100', 'springboot thymeleaf和shiro 整合——按钮可见性', null, null, null, '<p style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; margin-bottom: 16px; color: rgb(61, 70, 77); font-family: &quot;Pingfang SC&quot;, STHeiti, &quot;Lantinghei SC&quot;, &quot;Open Sans&quot;, Arial, &quot;Hiragino Sans GB&quot;, &quot;Microsoft YaHei&quot;, &quot;WenQuanYi Micro Hei&quot;, SimSun, sans-serif; font-size: 16px; background-color: rgb(248, 248, 248);\">添加依赖</p><pre class=\"hljs xml\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; padding: 2px; background: rgb(63, 63, 63); color: rgb(220, 220, 220); border-radius: 3px; line-height: 1.4; word-wrap: normal; font-family: Menlo, Monaco, Consolas, &quot;Courier New&quot;, monospace;\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\">&lt;<span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\">dependency</span>&gt;</span><code class=\"hljs xml\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; display: block; overflow-x: auto; padding: 10px; background: rgb(63, 63, 63); color: rgb(220, 220, 220); border-radius: 4px; font-size: 13px; line-height: 1.4; word-wrap: normal; font-family: Menlo, Monaco, Consolas, &quot;Courier New&quot;, monospace;\"> \r\n   <span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&lt;</span><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\">groupId</span></span></span><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&gt;</span></span>com.github.theborakompanioni<span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&lt;/</span><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\">groupId</span></span></span><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&gt;</span></span>\r\n    <span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&lt;</span><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\">artifactId</span></span></span><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&gt;</span></span>thymeleaf-extras-shiro<span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&lt;/</span><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\">artifactId</span></span></span><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&gt;</span></span>\r\n    <span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&lt;</span><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\">version</span></span></span><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&gt;</span></span></code>1.2.1<code class=\"hljs xml\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; display: block; overflow-x: auto; padding: 10px; background: rgb(63, 63, 63); color: rgb(220, 220, 220); border-radius: 4px; font-size: 13px; line-height: 1.4; word-wrap: normal; font-family: Menlo, Monaco, Consolas, &quot;Courier New&quot;, monospace;\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&lt;/</span><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\">version</span></span></span><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&gt;</span></span> \r\n<span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&lt;/</span><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\"><span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\">dependency</span></span></span><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">&gt;</span></span></code></pre><p style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; margin-bottom: 16px; color: rgb(61, 70, 77); font-family: &quot;Pingfang SC&quot;, STHeiti, &quot;Lantinghei SC&quot;, &quot;Open Sans&quot;, Arial, &quot;Hiragino Sans GB&quot;, &quot;Microsoft YaHei&quot;, &quot;WenQuanYi Micro Hei&quot;, SimSun, sans-serif; font-size: 16px; background-color: rgb(248, 248, 248);\">&nbsp;</p><p style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; margin-bottom: 16px; color: rgb(61, 70, 77); font-family: &quot;Pingfang SC&quot;, STHeiti, &quot;Lantinghei SC&quot;, &quot;Open Sans&quot;, Arial, &quot;Hiragino Sans GB&quot;, &quot;Microsoft YaHei&quot;, &quot;WenQuanYi Micro Hei&quot;, SimSun, sans-serif; font-size: 16px; background-color: rgb(248, 248, 248);\">在shiro的configuration中配置</p><pre class=\"hljs java\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; padding: 2px; background: rgb(63, 63, 63); color: rgb(220, 220, 220); border-radius: 3px; line-height: 1.4; word-wrap: normal; font-family: Menlo, Monaco, Consolas, &quot;Courier New&quot;, monospace;\"><span class=\"hljs-meta\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(127, 159, 127);\">@Bean</span>\r\n    <span class=\"hljs-function\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\"><span class=\"hljs-keyword\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\">public</span> ShiroDialect <span class=\"hljs-title\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\">shiroDialect</span><span class=\"hljs-params\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">()</span> </span>{\r\n        <span class=\"hljs-keyword\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\">return</span> <span class=\"hljs-keyword\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\">new</span> ShiroDialect();\r\n    }</pre><p style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; margin-bottom: 16px; color: rgb(61, 70, 77); font-family: &quot;Pingfang SC&quot;, STHeiti, &quot;Lantinghei SC&quot;, &quot;Open Sans&quot;, Arial, &quot;Hiragino Sans GB&quot;, &quot;Microsoft YaHei&quot;, &quot;WenQuanYi Micro Hei&quot;, SimSun, sans-serif; font-size: 16px; background-color: rgb(248, 248, 248);\">&nbsp;</p><p style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; margin-bottom: 16px; color: rgb(61, 70, 77); font-family: &quot;Pingfang SC&quot;, STHeiti, &quot;Lantinghei SC&quot;, &quot;Open Sans&quot;, Arial, &quot;Hiragino Sans GB&quot;, &quot;Microsoft YaHei&quot;, &quot;WenQuanYi Micro Hei&quot;, SimSun, sans-serif; font-size: 16px; background-color: rgb(248, 248, 248);\">在html中加入xmlns</p><pre class=\"hljs xml\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; padding: 2px; background: rgb(63, 63, 63); color: rgb(220, 220, 220); border-radius: 3px; line-height: 1.4; word-wrap: normal; font-family: Menlo, Monaco, Consolas, &quot;Courier New&quot;, monospace;\"><span class=\"hljs-tag\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\">&lt;<span class=\"hljs-name\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(239, 239, 143);\">html</span> <span class=\"hljs-attr\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">lang</span>=<span class=\"hljs-string\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(204, 147, 147);\">\"zh_CN\"</span> <span class=\"hljs-attr\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">xmlns:th</span>=<span class=\"hljs-string\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(204, 147, 147);\">\"http://www.thymeleaf.org\"</span>\r\n      <span class=\"hljs-attr\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\">xmlns:shiro</span>=<span class=\"hljs-string\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(204, 147, 147);\">\"http://www.pollix.at/thymeleaf/shiro\"</span>&gt;</span></pre><p style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; margin-bottom: 16px; color: rgb(61, 70, 77); font-family: &quot;Pingfang SC&quot;, STHeiti, &quot;Lantinghei SC&quot;, &quot;Open Sans&quot;, Arial, &quot;Hiragino Sans GB&quot;, &quot;Microsoft YaHei&quot;, &quot;WenQuanYi Micro Hei&quot;, SimSun, sans-serif; font-size: 16px; background-color: rgb(248, 248, 248);\">例子</p><pre class=\"hljs scala\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; padding: 2px; background: rgb(63, 63, 63); color: rgb(220, 220, 220); border-radius: 3px; line-height: 1.4; word-wrap: normal; font-family: Menlo, Monaco, Consolas, &quot;Courier New&quot;, monospace;\">&lt;button shiro:hasPermission=<span class=\"hljs-string\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(204, 147, 147);\">\"sys:user:add\"</span> <span class=\"hljs-class\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\"><span class=\"hljs-keyword\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\">type</span></span>=<span class=\"hljs-string\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(204, 147, 147);\">\"button\"</span> <span class=\"hljs-class\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\"><span class=\"hljs-keyword\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\">class</span></span>=<span class=\"hljs-string\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(204, 147, 147);\">\"btn &nbsp;btn-primary\"</span> onclick=<span class=\"hljs-string\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(204, 147, 147);\">\"add()\"</span>&gt;\r\n&nbsp;&nbsp; &lt;i <span class=\"hljs-class\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent;\"><span class=\"hljs-keyword\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(227, 206, 171);\">class</span></span>=<span class=\"hljs-string\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(204, 147, 147);\">\"fa fa-plus\"</span> aria-hidden=<span class=\"hljs-string\" style=\"box-sizing: inherit; -webkit-tap-highlight-color: transparent; color: rgb(204, 147, 147);\">\"true\"</span>&gt;&lt;/i&gt;添加\r\n&lt;/button&gt;</pre>', 'article', null, null, null, null, '1', null, '0', '1', 'bootdo', '2017-09-22 13:24:30', '2017-09-22 13:24:30'), ('108', 'spring boot ehcache整合', null, null, null, '<h3 id=\"pomxml配置-引入依赖包\" style=\"font-family: &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, SimHei, Arial, SimSun; color: rgb(63, 63, 63); margin: 0.8em 0px; font-size: 1.7em; padding: 0px;\">pom.xml配置 引入依赖包</h3><pre class=\"prettyprint\" style=\"font-family: &quot;Source Code Pro&quot;, monospace; font-size: 14px; white-space: nowrap; padding: 5px 5px 5px 60px; margin-bottom: 1.1em; line-height: 1.45; background-color: rgba(128, 128, 128, 0.05); border-color: rgba(128, 128, 128, 0.075); border-radius: 0px; position: relative; overflow-y: hidden;\"><code class=\"hljs xml has-numbering\" style=\"font-family: &quot;Source Code Pro&quot;, monospace; white-space: pre; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; display: block; word-wrap: normal;\"><span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">dependency</span>&gt;</span>\r\n    <span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">groupId</span>&gt;</span>org.springframework.boot<span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;/<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">groupId</span>&gt;</span>\r\n    <span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">artifactId</span>&gt;</span>spring-boot-starter-cache<span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;/<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">artifactId</span>&gt;</span>\r\n<span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;/<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">dependency</span>&gt;</span>\r\n<span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">dependency</span>&gt;</span>\r\n    <span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">groupId</span>&gt;</span>net.sf.ehcache<span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;/<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">groupId</span>&gt;</span>\r\n    <span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">artifactId</span>&gt;</span>ehcache<span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;/<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">artifactId</span>&gt;</span>\r\n<span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;/<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">dependency</span>&gt;</span></code><ul class=\"pre-numbering\" style=\"margin-right: 0px; margin-bottom: 0px; margin-left: 0px; padding: 6px 0px 40px; list-style: none; position: absolute; width: 50px; background-color: rgb(238, 238, 238); top: 0px; left: 0px; border-right: 1px solid rgb(221, 221, 221); text-align: right;\"><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">1</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">2</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">3</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">4</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">5</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">6</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">7</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">8</li></ul></pre><h3 id=\"编写配置类设置缓存机制\" style=\"font-family: &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, SimHei, Arial, SimSun; color: rgb(63, 63, 63); margin: 0.8em 0px; font-size: 1.7em; padding: 0px;\">编写配置类,设置缓存机制</h3><pre class=\"prettyprint\" style=\"font-family: &quot;Source Code Pro&quot;, monospace; font-size: 14px; white-space: nowrap; padding: 5px 5px 5px 60px; margin-bottom: 1.1em; line-height: 1.45; background-color: rgba(128, 128, 128, 0.05); border-color: rgba(128, 128, 128, 0.075); border-radius: 0px; position: relative; overflow-y: hidden;\"><code class=\"hljs java has-numbering\" style=\"font-family: &quot;Source Code Pro&quot;, monospace; white-space: pre; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; display: block; word-wrap: normal;\"><span class=\"hljs-annotation\" style=\"margin: 0px; padding: 0px; color: rgb(155, 133, 157);\">@Configuration</span>\r\n<span class=\"hljs-annotation\" style=\"margin: 0px; padding: 0px; color: rgb(155, 133, 157);\">@EnableCaching</span>\r\n<span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">public</span> <span class=\"hljs-class\" style=\"margin: 0px; padding: 0px;\"><span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">class</span> <span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">CacheConfiguration</span> {</span>\r\n\r\n    <span class=\"hljs-annotation\" style=\"margin: 0px; padding: 0px; color: rgb(155, 133, 157);\">@Bean</span>\r\n    <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">public</span> EhCacheCacheManager <span class=\"hljs-title\" style=\"margin: 0px; padding: 0px;\">ehCacheCacheManager</span>(EhCacheManagerFactoryBean bean) {\r\n        <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">return</span> <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">new</span> EhCacheCacheManager(bean.getObject());\r\n    }\r\n\r\n    <span class=\"hljs-annotation\" style=\"margin: 0px; padding: 0px; color: rgb(155, 133, 157);\">@Bean</span>\r\n    <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">public</span> EhCacheManagerFactoryBean <span class=\"hljs-title\" style=\"margin: 0px; padding: 0px;\">ehCacheManagerFactoryBean</span>() {\r\n        EhCacheManagerFactoryBean cacheManagerFactoryBean = <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">new</span> EhCacheManagerFactoryBean();\r\n        cacheManagerFactoryBean.setConfigLocation(<span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">new</span> ClassPathResource(<span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"config/ehcache.xml\"</span>));\r\n        cacheManagerFactoryBean.setShared(<span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">true</span>);\r\n        <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">return</span> cacheManagerFactoryBean;\r\n    }\r\n}</code><ul class=\"pre-numbering\" style=\"margin-right: 0px; margin-bottom: 0px; margin-left: 0px; padding: 6px 0px 40px; list-style: none; position: absolute; width: 50px; background-color: rgb(238, 238, 238); top: 0px; left: 0px; border-right: 1px solid rgb(221, 221, 221); text-align: right;\"><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">1</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">2</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">3</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">4</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">5</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">6</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">7</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">8</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">9</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">10</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">11</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">12</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">13</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">14</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">15</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">16</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">17</li></ul></pre><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(63, 63, 63); font-family: &quot;microsoft yahei&quot;; font-size: 15px;\">ehcache.xml配置:</p><pre class=\"prettyprint\" style=\"font-family: &quot;Source Code Pro&quot;, monospace; font-size: 14px; white-space: nowrap; padding: 5px 5px 5px 60px; margin-bottom: 1.1em; line-height: 1.45; background-color: rgba(128, 128, 128, 0.05); border-color: rgba(128, 128, 128, 0.075); border-radius: 0px; position: relative; overflow-y: hidden;\"><code class=\"hljs xml has-numbering\" style=\"font-family: &quot;Source Code Pro&quot;, monospace; white-space: pre; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; display: block; word-wrap: normal;\"><span class=\"hljs-pi\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;?xml version=\"1.0\" encoding=\"UTF-8\"?&gt;</span>\r\n<span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">ehcache</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">xmlns:xsi</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"http://www.w3.org/2001/XMLSchema-instance\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">xsi:noNamespaceSchemaLocation</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"http://ehcache.org/ehcache.xsd\"</span>\r\n    <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">updateCheck</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"false\"</span>&gt;</span>\r\n    <span class=\"hljs-comment\" style=\"margin: 0px; padding: 0px; color: rgb(136, 0, 0);\">&lt;!-- diskStore：为缓存路径，ehcache分为内存和磁盘两级，此属性定义磁盘的缓存位置。\r\n    参数解释如下： user.home – 用户主目录 \r\n    user.dir – 用户当前工作目录 \r\n    java.io.tmpdir – 默认临时文件路径 --&gt;</span>\r\n    <span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">diskStore</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">path</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"java.io.tmpdir/Tmp_EhCache\"</span> /&gt;</span>\r\n    <span class=\"hljs-comment\" style=\"margin: 0px; padding: 0px; color: rgb(136, 0, 0);\">&lt;!-- defaultCache：默认缓存策略，当ehcache找不到定义的缓存时，则使用这个缓存策略。只能定义一个。 --&gt;</span>\r\n    <span class=\"hljs-comment\" style=\"margin: 0px; padding: 0px; color: rgb(136, 0, 0);\">&lt;!-- name:缓存名称。 \r\n        maxElementsInMemory:缓存最大数目\r\n        maxElementsOnDisk：硬盘最大缓存个数。 \r\n        eternal:对象是否永久有效，一但设置了，timeout将不起作用。 \r\n        overflowToDisk:是否保存到磁盘，当系统当机时 \r\n        timeToIdleSeconds:设置对象在失效前的允许闲置时间（单位：秒）。仅当eternal=false对象不是永久有效时使 用，可选属性，默认值是0，也就是可闲置时间无穷大。\r\n        timeToLiveSeconds:设置对象在失效前允许存活时间（单位：秒）。最大时间介于创建时间和失效时间之间。仅 当eternal=false对象不是永久有效时使用，默认是0.，也就是对象存活时间无穷大。 \r\n        diskPersistent：是否缓存虚拟机重启期数据Whether the disk store persists between restarts \r\n        of the Virtual Machine. The default value is false. \r\n        diskSpoolBufferSizeMB：这个参数设置DiskStore（磁盘缓存）的缓存区大小。默认是30MB。每个Cache都应该 有自己的一个缓冲区。 \r\n        diskExpiryThreadIntervalSeconds：磁盘失效线程运行时间间隔，默认是120秒。 \r\n        memoryStoreEvictionPolicy：当达到maxElementsInMemory限制时，Ehcache将会根据指定的策略去清理内 存。默认策略是LRU（最近最少使用）。\r\n        你可以设置为FIFO（先进先出）或是LFU（较少使用）。 \r\n        clearOnFlush：内存数量最大时是否清除。\r\n        memoryStoreEvictionPolicy:可选策略有：LRU（最近最少使用，默认策略）、FIFO（先进先出）、LFU（最少 访问次数）。 \r\n         FIFO，first in first out，这个是大家最熟的，先进先出。\r\n         LFU， Less Frequently Used，就是上面例子中使用的策略，直白一点就是讲一直以来最少被使用的。如上面 所讲，缓存的元素有一个hit属性，hit值最小的将会被清出缓存。 \r\n         LRU，Least Recently Used，最近最少使用的，缓存的元素有一个时间戳，当缓存容量满了，而又需要腾出地 方来缓存新的元素的时候，\r\n         那么现有缓存元素中时间戳离当前时间最远的元素将被清出缓存。 --&gt;</span>\r\n    <span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">defaultCache</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">eternal</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"false\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">maxElementsInMemory</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"1000\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">overflowToDisk</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"false\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">diskPersistent</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"false\"</span>\r\n        <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">timeToIdleSeconds</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"0\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">timeToLiveSeconds</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"600\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">memoryStoreEvictionPolicy</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"LRU\"</span> /&gt;</span>\r\n    <span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">cache</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">name</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"snailAuthCache\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">eternal</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"false\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">maxElementsInMemory</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"10000\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">overflowToDisk</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"false\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">diskPersistent</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"false\"</span>\r\n        <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">timeToIdleSeconds</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"0\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">timeToLiveSeconds</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"0\"</span> <span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">memoryStoreEvictionPolicy</span>=<span class=\"hljs-value\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"LFU\"</span> /&gt;</span>\r\n<span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;/<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">ehcache</span>&gt;</span></code><ul class=\"pre-numbering\" style=\"margin-right: 0px; margin-bottom: 0px; margin-left: 0px; padding: 6px 0px 40px; list-style: none; position: absolute; width: 50px; background-color: rgb(238, 238, 238); top: 0px; left: 0px; border-right: 1px solid rgb(221, 221, 221); text-align: right;\"><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">1</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">2</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">3</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">4</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">5</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">6</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">7</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">8</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">9</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">10</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">11</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">12</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">13</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">14</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">15</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">16</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">17</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">18</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">19</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">20</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">21</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">22</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">23</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">24</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">25</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">26</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">27</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">28</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">29</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">30</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">31</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">32</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">33</li></ul><div class=\"save_code tracking-ad\" data-mod=\"popu_249\" style=\"margin: 0px; padding: 0px; position: absolute; height: 60px; right: 30px; top: 5px; color: rgb(255, 255, 255); cursor: pointer; z-index: 2;\"><a style=\"color: rgb(202, 12, 22); margin: 0px; padding: 0px; outline: none;\"><img src=\"http://static.blog.csdn.net/images/save_snippets.png\" style=\"outline: none; max-width: 100%;\"></a></div></pre><h3 id=\"测试\" style=\"font-family: &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, SimHei, Arial, SimSun; color: rgb(63, 63, 63); margin: 0.8em 0px; font-size: 1.7em; padding: 0px;\"><br></h3>', 'article', null, null, null, null, '1', null, '0', '1', 'bootdo', '2017-09-22 17:48:29', '2017-09-22 17:48:29'), ('109', 'spring-boot整合ehcache实现缓存机制', null, null, null, '<p><br></p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　EhCache 是一个纯Java的进程内缓存框架，具有快速、精干等特点，是Hibernate中默认的CacheProvider。</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　ehcache提供了多种缓存策略，主要分为内存和磁盘两级，所以无需担心容量问题。</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　spring-boot是一个快速的集成框架，其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置，从而使开发人员不再需要定义样板化的配置。</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　由于spring-boot无需任何样板化的配置文件，所以spring-boot集成一些其他框架时会有略微的不同。</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　1.spring-boot是一个通过maven管理的jar包的框架，集成ehcache需要的依赖如下</p><div class=\"cnblogs_code\" style=\"background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); padding: 5px; overflow: auto; margin: 5px 0px; color: rgb(0, 0, 0); font-family: &quot;Courier New&quot; !important; font-size: 12px !important;\"><div class=\"cnblogs_code_toolbar\" style=\"margin-top: 5px;\"><span class=\"cnblogs_code_copy\" style=\"padding-right: 5px; line-height: 1.5 !important;\"><a title=\"复制代码\" style=\"color: rgb(86, 182, 233); background-color: rgb(245, 245, 245) !important; border: none !important;\"><img src=\"http://common.cnblogs.com/images/copycode.gif\" alt=\"复制代码\" style=\"max-width: 900px; border-width: initial !important; border-style: none !important;\"></a></span></div><pre style=\"margin-bottom: 0px; line-height: 1.42857; font-family: &quot;Courier New&quot; !important; font-size: 12px !important;\"> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>org.springframework<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n     <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>spring-context-support<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n         <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>net.sf.ehcache<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n      <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>ehcache<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n          <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">version</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>2.8.3<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">version</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>        </pre><div class=\"cnblogs_code_toolbar\" style=\"margin-top: 5px;\"><span class=\"cnblogs_code_copy\" style=\"padding-right: 5px; line-height: 1.5 !important;\"><a title=\"复制代码\" style=\"color: rgb(86, 182, 233); background-color: rgb(245, 245, 245) !important; border: none !important;\"><img src=\"http://common.cnblogs.com/images/copycode.gif\" alt=\"复制代码\" style=\"max-width: 900px; border-width: initial !important; border-style: none !important;\"></a></span></div></div><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　　　具体pom.xml文件如下</p><div class=\"cnblogs_code\" style=\"background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); padding: 5px; overflow: auto; margin: 5px 0px; color: rgb(0, 0, 0); font-family: &quot;Courier New&quot; !important; font-size: 12px !important;\"><div class=\"cnblogs_code_toolbar\" style=\"margin-top: 5px;\"><span class=\"cnblogs_code_copy\" style=\"padding-right: 5px; line-height: 1.5 !important;\"><a title=\"复制代码\" style=\"color: rgb(86, 182, 233); background-color: rgb(245, 245, 245) !important; border: none !important;\"><img src=\"http://common.cnblogs.com/images/copycode.gif\" alt=\"复制代码\" style=\"max-width: 900px; border-width: initial !important; border-style: none !important;\"></a></span></div><pre style=\"margin-bottom: 0px; line-height: 1.42857; font-family: &quot;Courier New&quot; !important; font-size: 12px !important;\"><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;?</span><span style=\"color: rgb(255, 0, 255); line-height: 1.5 !important;\">xml version=\"1.0\" encoding=\"UTF-8\"</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">?&gt;</span>\r\n<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">project </span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\">xmlns</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"http://maven.apache.org/POM/4.0.0\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> xmlns:xsi</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"http://www.w3.org/2001/XMLSchema-instance\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\">\r\n    xsi:schemaLocation</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd\"</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">modelVersion</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>4.0.0<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">modelVersion</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>com.lclc.boot<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>boot-cache<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">version</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>0.0.1-SNAPSHOT<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">version</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">&lt;!--</span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\"> Inherit defaults from Spring Boot </span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">--&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">parent</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>org.springframework.boot<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>spring-boot-starter-parent<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">version</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>1.1.3.RELEASE<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">version</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">parent</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependencies</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>org.springframework.boot<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>spring-boot-starter-web<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>org.springframework.boot<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>spring-boot-starter-data-jpa<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>org.springframework.boot<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>spring-boot-starter-thymeleaf<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        \r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>mysql<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>mysql-connector-java<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>com.google.guava<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>guava<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">version</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>17.0<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">version</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        \r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>org.springframework<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>spring-context-support<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>net.sf.ehcache<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>ehcache<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">version</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>2.8.3<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">version</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependency</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependencies</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependencyManagement</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependencies</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependencies</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">dependencyManagement</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">build</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">plugins</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">plugin</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n                <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>org.springframework.boot<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">groupId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n                <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>spring-boot-maven-plugin<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">artifactId</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">plugin</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">plugins</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">build</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">repositories</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">repository</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">id</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>spring-snapshots<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">id</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">url</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>http://repo.spring.io/snapshot<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">url</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">snapshots</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n                <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">enabled</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>true<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">enabled</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">snapshots</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">repository</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">repository</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">id</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>spring-milestones<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">id</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">url</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>http://repo.spring.io/milestone<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">url</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">repository</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">repositories</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">pluginRepositories</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">pluginRepository</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">id</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>spring-snapshots<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">id</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">url</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>http://repo.spring.io/snapshot<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">url</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">pluginRepository</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">pluginRepository</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">id</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>spring-milestones<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">id</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">url</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>http://repo.spring.io/milestone<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">url</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n        <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">pluginRepository</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">pluginRepositories</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n\r\n<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">project</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span></pre><div class=\"cnblogs_code_toolbar\" style=\"margin-top: 5px;\"><span class=\"cnblogs_code_copy\" style=\"padding-right: 5px; line-height: 1.5 !important;\"><a title=\"复制代码\" style=\"color: rgb(86, 182, 233); background-color: rgb(245, 245, 245) !important; border: none !important;\"><img src=\"http://common.cnblogs.com/images/copycode.gif\" alt=\"复制代码\" style=\"max-width: 900px; border-width: initial !important; border-style: none !important;\"></a></span></div></div><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">&nbsp;　　2.使用ehcache，我们需要一个ehcache.xml来定义一些cache的属性。</p><div class=\"cnblogs_code\" style=\"background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); padding: 5px; overflow: auto; margin: 5px 0px; color: rgb(0, 0, 0); font-family: &quot;Courier New&quot; !important; font-size: 12px !important;\"><div class=\"cnblogs_code_toolbar\" style=\"margin-top: 5px;\"><span class=\"cnblogs_code_copy\" style=\"padding-right: 5px; line-height: 1.5 !important;\"><a title=\"复制代码\" style=\"color: rgb(86, 182, 233); background-color: rgb(245, 245, 245) !important; border: none !important;\"><img src=\"http://common.cnblogs.com/images/copycode.gif\" alt=\"复制代码\" style=\"max-width: 900px; border-width: initial !important; border-style: none !important;\"></a></span></div><pre style=\"margin-bottom: 0px; line-height: 1.42857; font-family: &quot;Courier New&quot; !important; font-size: 12px !important;\"><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;?</span><span style=\"color: rgb(255, 0, 255); line-height: 1.5 !important;\">xml version=\"1.0\" encoding=\"UTF-8\"</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">?&gt;</span>\r\n<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">ehcache </span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\">xmlns:xsi</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"http://www.w3.org/2001/XMLSchema-instance\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> xsi:noNamespaceSchemaLocation</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"http://ehcache.org/ehcache.xsd\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\">\r\n  updateCheck</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"false\"</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span>\r\n          <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">diskStore </span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\">path</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"java.io.tmpdir/Tmp_EhCache\"</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">/&gt;</span>\r\n           <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">defaultCache </span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\">eternal</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"false\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> maxElementsInMemory</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"1000\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> overflowToDisk</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"false\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> diskPersistent</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"false\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\">\r\n    timeToIdleSeconds</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"0\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> timeToLiveSeconds</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"600\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> memoryStoreEvictionPolicy</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"LRU\"</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">/&gt;</span>\r\n\r\n            <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">cache </span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\">name</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"demo\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> eternal</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"false\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> maxElementsInMemory</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"100\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> overflowToDisk</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"false\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> diskPersistent</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"false\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\">\r\n    timeToIdleSeconds</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"0\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> timeToLiveSeconds</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"300\"</span><span style=\"color: rgb(255, 0, 0); line-height: 1.5 !important;\"> memoryStoreEvictionPolicy</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">=\"LRU\"</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">/&gt;</span>\r\n\r\n<span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&lt;/</span><span style=\"color: rgb(128, 0, 0); line-height: 1.5 !important;\">ehcache</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">&gt;</span></pre><div class=\"cnblogs_code_toolbar\" style=\"margin-top: 5px;\"><span class=\"cnblogs_code_copy\" style=\"padding-right: 5px; line-height: 1.5 !important;\"><a title=\"复制代码\" style=\"color: rgb(86, 182, 233); background-color: rgb(245, 245, 245) !important; border: none !important;\"><img src=\"http://common.cnblogs.com/images/copycode.gif\" alt=\"复制代码\" style=\"max-width: 900px; border-width: initial !important; border-style: none !important;\"></a></span></div></div><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">&nbsp;　　解释下这个xml文件中的标签。</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　(1).<span style=\"color: rgb(128, 0, 0);\">diskStore：</span>&nbsp;为缓存路径，ehcache分为内存和磁盘两级，此属性定义磁盘的缓存位置。参数解释如下：　　　　<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 　　　　user.home – 用户主目录<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 　　　 　user.dir&nbsp; – 用户当前工作目录<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;　　　　&nbsp; java.io.tmpdir – 默认临时文件路径</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　(2).<span style=\"color: rgb(128, 0, 0);\">defaultCache：<span style=\"color: rgb(0, 0, 0);\">默认缓存策略，当ehcache找不到定义的缓存时，则使用这个缓存策略。只能定义一个。</span></span></p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\"><span style=\"color: rgb(128, 0, 0);\"><span style=\"color: rgb(0, 0, 0);\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; (3).<span style=\"color: rgb(128, 0, 0);\">cache</span>：自定缓存策略，为自定义的缓存策略。参数解释如下：</span></span></p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\"><span style=\"color: rgb(128, 0, 0);\"><span style=\"color: rgb(0, 0, 0);\">　　　 cache元素的属性：&nbsp; &nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; name：缓存名称&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; maxElementsInMemory：内存中最大缓存对象数&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; maxElementsOnDisk：硬盘中最大缓存对象数，若是0表示无穷大&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; eternal：true表示对象永不过期，此时会忽略timeToIdleSeconds和timeToLiveSeconds属性，默认为false &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; overflowToDisk：true表示当内存缓存的对象数目达到了maxElementsInMemory界限后，会把溢出的对象写到硬盘缓存中。注意：如果缓存的对象要写入到硬盘中的话，则该对象必须实现了Serializable接口才行。&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; diskSpoolBufferSizeMB：磁盘缓存区大小，默认为30MB。每个Cache都应该有自己的一个缓存区。&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; diskPersistent：是否缓存虚拟机重启期数据&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; diskExpiryThreadIntervalSeconds：磁盘失效线程运行时间间隔，默认为120秒&nbsp; &nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; timeToIdleSeconds： 设定允许对象处于空闲状态的最长时间，以秒为单位。当对象自从最近一次被访问后，如果处于空闲状态的时间超过了timeToIdleSeconds属性值，这个对象就会过期，EHCache将把它从缓存中清空。只有当eternal属性为false，该属性才有效。如果该属性值为0，则表示对象可以无限期地处于空闲状态&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; timeToLiveSeconds：设定对象允许存在于缓存中的最长时间，以秒为单位。当对象自从被存放到缓存中后，如果处于缓存中的时间超过了 timeToLiveSeconds属性值，这个对象就会过期，EHCache将把它从缓存中清除。只有当eternal属性为false，该属性才有效。如果该属性值为0，则表示对象可以无限期地存在于缓存中。timeToLiveSeconds必须大于timeToIdleSeconds属性，才有意义&nbsp; &nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; memoryStoreEvictionPolicy：当达到maxElementsInMemory限制时，Ehcache将会根据指定的策略去清理内存。可选策略有：LRU（最近最少使用，默认策略）、FIFO（先进先出）、LFU（最少访问次数）。&nbsp;&nbsp;</span></span></p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">&nbsp;</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\"><span style=\"color: rgb(128, 0, 0);\"><span style=\"color: rgb(0, 0, 0);\">　　3.将ehcache的管理器暴露给spring的上下文容器，</span></span></p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\"><span style=\"color: rgb(128, 0, 0);\"><span style=\"color: rgb(0, 0, 0);\">　　</span></span></p><div class=\"cnblogs_code\" style=\"background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); padding: 5px; overflow: auto; margin: 5px 0px; color: rgb(0, 0, 0); font-family: &quot;Courier New&quot; !important; font-size: 12px !important;\"><div class=\"cnblogs_code_toolbar\" style=\"margin-top: 5px;\"><span class=\"cnblogs_code_copy\" style=\"padding-right: 5px; line-height: 1.5 !important;\"><a title=\"复制代码\" style=\"color: rgb(86, 182, 233); background-color: rgb(245, 245, 245) !important; border: none !important;\"><img src=\"http://common.cnblogs.com/images/copycode.gif\" alt=\"复制代码\" style=\"max-width: 900px; border-width: initial !important; border-style: none !important;\"></a></span></div><pre style=\"margin-bottom: 0px; line-height: 1.42857; font-family: &quot;Courier New&quot; !important; font-size: 12px !important;\"><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">@Configuration\r\n</span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">//</span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\"> 标注启动了缓存</span>\r\n<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">@EnableCaching\r\n</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">public</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">class</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> CacheConfiguration {\r\n\r\n    </span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">/*</span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">\r\n     * ehcache 主要的管理器\r\n     </span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">*/</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">\r\n    @Bean(name </span>= \"appEhCacheCacheManager\"<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">)\r\n    </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">public</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> EhCacheCacheManager ehCacheCacheManager(EhCacheManagerFactoryBean bean){\r\n        </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">return</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">new</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> EhCacheCacheManager (bean.getObject ());\r\n    }\r\n\r\n    </span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">/*</span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">\r\n     * 据shared与否的设置,Spring分别通过CacheManager.create()或new CacheManager()方式来创建一个ehcache基地.\r\n     </span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">*/</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">\r\n    @Bean\r\n    </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">public</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> EhCacheManagerFactoryBean ehCacheManagerFactoryBean(){\r\n        EhCacheManagerFactoryBean cacheManagerFactoryBean </span>= <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">new</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> EhCacheManagerFactoryBean ();\r\n        cacheManagerFactoryBean.setConfigLocation (</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">new</span> ClassPathResource (\"conf/ehcache-app.xml\"<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">));\r\n        cacheManagerFactoryBean.setShared (</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">true</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">);\r\n        </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">return</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> cacheManagerFactoryBean;\r\n    }\r\n}</span></pre><div class=\"cnblogs_code_toolbar\" style=\"margin-top: 5px;\"><span class=\"cnblogs_code_copy\" style=\"padding-right: 5px; line-height: 1.5 !important;\"><a title=\"复制代码\" style=\"color: rgb(86, 182, 233); background-color: rgb(245, 245, 245) !important; border: none !important;\"><img src=\"http://common.cnblogs.com/images/copycode.gif\" alt=\"复制代码\" style=\"max-width: 900px; border-width: initial !important; border-style: none !important;\"></a></span></div></div><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">&nbsp;</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">&nbsp;&nbsp; 　　　　<span style=\"color: rgb(0, 0, 0);\">@Configuration</span>：为spring-boot注解，主要标注此为配置类，优先扫描。</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">&nbsp; 　　　　<span style=\"color: rgb(0, 0, 0);\">@Bean</span>：向spring容器中加入bean。</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　至此所有的配置都做好了，通过spring-boot进行集成框架就是这么简单。</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　4.使用ehcache</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　　　使用ehcache主要通过spring的缓存机制，上面我们将spring的缓存机制使用了ehcache进行实现，所以使用方面就完全使用spring缓存机制就行了。<br>　　　　具体牵扯到几个注解：</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　　　@Cacheable：负责将方法的返回值加入到缓存中，参数3<br>　　　　@CacheEvict：负责清除缓存，参数4</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　　　　参数解释：</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　　　value：缓存位置名称，不能为空，如果使用EHCache，就是ehcache.xml中声明的cache的name<br>　　　　key：缓存的key，默认为空，既表示使用方法的参数类型及参数值作为key，支持SpEL<br>　　　　condition：触发条件，只有满足条件的情况才会加入缓存，默认为空，既表示全部都加入缓存，支持SpEL</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　　　allEntries：CacheEvict参数，true表示清除value中的全部缓存，默认为false</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　不多说，直接上代码：</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　</p><div class=\"cnblogs_code\" style=\"background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); padding: 5px; overflow: auto; margin: 5px 0px; color: rgb(0, 0, 0); font-family: &quot;Courier New&quot; !important; font-size: 12px !important;\"><div class=\"cnblogs_code_toolbar\" style=\"margin-top: 5px;\"><span class=\"cnblogs_code_copy\" style=\"padding-right: 5px; line-height: 1.5 !important;\"><a title=\"复制代码\" style=\"color: rgb(86, 182, 233); background-color: rgb(245, 245, 245) !important; border: none !important;\"><img src=\"http://common.cnblogs.com/images/copycode.gif\" alt=\"复制代码\" style=\"max-width: 900px; border-width: initial !important; border-style: none !important;\"></a></span></div><pre style=\"margin-bottom: 0px; line-height: 1.42857; font-family: &quot;Courier New&quot; !important; font-size: 12px !important;\"><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">@Service\r\n</span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">public</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">class</span> CacheDemoServiceImpl <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">implements</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> CacheDemoService {\r\n\r\n    </span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">/**</span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">\r\n     * 缓存的key\r\n     </span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">*/</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">public</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">static</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">final</span> String THING_ALL_KEY   = \"\\\"thing_all\\\"\"<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">;\r\n    </span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">/**</span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">\r\n     * value属性表示使用哪个缓存策略，缓存策略在ehcache.xml\r\n     </span><span style=\"color: rgb(0, 128, 0); line-height: 1.5 !important;\">*/</span>\r\n    <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">public</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">static</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">final</span> String DEMO_CACHE_NAME = \"demo\"<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">;\r\n   \r\n    @CacheEvict(value </span>= DEMO_CACHE_NAME,key =<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> THING_ALL_KEY)\r\n    @Override\r\n    </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">public</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">void</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> create(Thing thing){\r\n        Long id </span>=<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> getNextId ();\r\n        thing.setId (id);\r\n        data.put (id, thing);\r\n    } \r\n      \r\n     @Cacheable(value </span>=<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> DEMO_CACHE_NAME,key = \"#thing.getId()+\'thing\'\")\r\n    @Override\r\n    </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">public</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> Thing findById(Long id){\r\n        System.err.println (</span>\"没有走缓存！\" +<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> id);\r\n        </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">return</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> data.get (id);\r\n    }\r\n\r\n      @Cacheable(value </span>= DEMO_CACHE_NAME,key =<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> THING_ALL_KEY)\r\n    @Override\r\n    </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">public</span> List&lt;Thing&gt;<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> findAll(){\r\n        </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">return</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> Lists.newArrayList (data.values ());\r\n    }\r\n   \r\n   </span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">\r\n      @Override\r\n    @CachePut(value </span>= DEMO_CACHE_NAME,key = \"#thing.getId()+\'thing\'\"<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\">)\r\n    @CacheEvict(value </span>= DEMO_CACHE_NAME,key =<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> THING_ALL_KEY)\r\n    </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">public</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> Thing update(Thing thing){\r\n        System.out.println (thing);\r\n        data.put (thing.getId (), thing);\r\n        </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">return</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> thing;\r\n    }\r\n\r\n    @CacheEvict(value </span>=<span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> DEMO_CACHE_NAME)\r\n    @Override\r\n    </span><span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">public</span> <span style=\"color: rgb(0, 0, 255); line-height: 1.5 !important;\">void</span><span style=\"color: rgb(0, 0, 0); line-height: 1.5 !important;\"> delete(Long id){\r\n        data.remove (id);\r\n    }\r\n   \r\n}</span></pre><div class=\"cnblogs_code_toolbar\" style=\"margin-top: 5px;\"><span class=\"cnblogs_code_copy\" style=\"padding-right: 5px; line-height: 1.5 !important;\"><a title=\"复制代码\" style=\"color: rgb(86, 182, 233); background-color: rgb(245, 245, 245) !important; border: none !important;\"><img src=\"http://common.cnblogs.com/images/copycode.gif\" alt=\"复制代码\" style=\"max-width: 900px; border-width: initial !important; border-style: none !important;\"></a></span></div></div><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">&nbsp;</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">　　　　5.只需要通过注解在service层方法上打注解便可以使用缓存，在find**上存入缓存，在delete**,update**上清除缓存。</p><p style=\"margin-top: 10px; margin-right: auto; margin-left: auto; color: rgb(35, 35, 35); font-family: Verdana, Arial, helvetica, sans-seriff; font-size: 14px;\">&nbsp;</p>', 'article', null, null, null, null, '1', null, '0', '1', 'bootdo', '2017-09-24 11:15:18', '2017-09-24 11:15:18');
INSERT INTO `blog_content` VALUES ('110', 'spring boot 图片上传后的图片读取路径在win与linux环境配置的差别', null, null, null, '<ol><li><p style=\"margin-bottom: 0px; padding: 0px; color: rgb(69, 69, 69); font-family: &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, SimHei, Arial, SimSun; font-size: 16px;\">win</p><p style=\"margin-bottom: 0px; padding: 0px; color: rgb(69, 69, 69); font-family: &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, SimHei, Arial, SimSun; font-size: 16px;\"></p><div class=\"dp-highlighter bg_java\" style=\"padding: 1px 0px 0px; font-family: Consolas, &quot;Courier New&quot;, Courier, mono, serif; font-size: 12px; background-color: rgb(231, 229, 220); width: 849.412px; overflow-x: auto; overflow-y: hidden; position: relative; color: rgb(69, 69, 69); margin: 18px 0px !important;\"><div class=\"bar\" style=\"margin: 0px; padding: 0px 0px 0px 45px;\"><div class=\"tools\" style=\"margin: 0px; padding: 3px 8px 10px 10px; font-stretch: normal; font-size: 9px; line-height: normal; font-family: Verdana, Geneva, Arial, Helvetica, sans-serif; color: silver; background-color: rgb(248, 248, 248); border-left: 3px solid rgb(108, 226, 108); border-right: 1px solid rgb(231, 229, 220);\"><b>[java]</b>&nbsp;<a href=\"http://blog.csdn.net/qq1115094858/article/details/51873698#\" class=\"ViewSource\" title=\"view plain\" style=\"background-image: url(&quot;images/default/ico_plain.gif&quot;); background-position: left top; background-repeat: no-repeat; color: rgb(202, 12, 22); margin: 0px 10px 0px 0px; padding: 1px; outline: none; border: none; font-size: 9px; display: inline-block; width: 16px; height: 16px; text-indent: -2000px;\">view plain</a><span class=\"tracking-ad\" data-mod=\"popu_168\" style=\"margin: 0px; padding: 0px;\">&nbsp;<a href=\"http://blog.csdn.net/qq1115094858/article/details/51873698#\" class=\"CopyToClipboard\" title=\"copy\" style=\"background-image: url(&quot;images/default/ico_copy.gif&quot;); background-position: left top; background-repeat: no-repeat; color: rgb(202, 12, 22); margin: 0px 10px 0px 0px; padding: 1px; outline: none; border: none; font-size: 9px; display: inline-block; width: 16px; height: 16px; text-indent: -2000px;\">copy</a><div style=\"margin: 0px; padding: 0px; position: absolute; left: 294px; top: 296px; width: 16px; height: 16px; z-index: 99;\"></div></span><span class=\"tracking-ad\" data-mod=\"popu_169\" style=\"margin: 0px; padding: 0px;\"></span></div></div><ol start=\"1\" class=\"dp-j\" style=\"padding: 0px; list-style-position: initial; list-style-image: initial; border-top: none; border-right: 1px solid rgb(231, 229, 220); border-bottom: none; border-left: none; border-image: initial; background-color: rgb(255, 255, 255); color: rgb(92, 92, 92); margin-right: 0px !important; margin-bottom: 1px !important; margin-left: 45px !important;\"><li class=\"alt\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; color: inherit; line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"annotation\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(100, 100, 100); background-color: inherit;\">@Component</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;&nbsp;</span></span></li><li class=\"\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; font-weight: bold; border: none; color: rgb(0, 102, 153); background-color: inherit;\">class</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;WebConfigurer&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; font-weight: bold; border: none; color: rgb(0, 102, 153); background-color: inherit;\">extends</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;WebMvcConfigurerAdapter&nbsp;{&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; color: inherit; line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"annotation\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(100, 100, 100); background-color: inherit;\">@Override</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;&nbsp;</span></span></li><li class=\"\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"keyword\" style=\"margin: 0px; padding: 0px; font-weight: bold; border: none; color: rgb(0, 102, 153); background-color: inherit;\">public</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; font-weight: bold; border: none; color: rgb(0, 102, 153); background-color: inherit;\">void</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;addResourceHandlers(ResourceHandlerRegistry&nbsp;registry)&nbsp;{&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; color: inherit; line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;registry.addResourceHandler(<span class=\"string\" style=\"margin: 0px; padding: 0px; border: none; color: blue; background-color: inherit;\">\"/files/**\"</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">).addResourceLocations(</span><span class=\"string\" style=\"margin: 0px; padding: 0px; border: none; color: blue; background-color: inherit;\">\"file:///E:/var/spring/uploaded_files/\"</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">);&nbsp;&nbsp;</span></span></li><li class=\"\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;</span></li><li class=\"alt\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; color: inherit; line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;</span></li><li class=\"\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">}&nbsp;&nbsp;</span></li></ol></div><span style=\"color: rgb(69, 69, 69); font-family: &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, SimHei, Arial, SimSun; font-size: 16px;\">linux</span><br style=\"color: rgb(69, 69, 69); font-family: &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, SimHei, Arial, SimSun; font-size: 16px;\"><div class=\"dp-highlighter bg_java\" style=\"padding: 1px 0px 0px; font-family: Consolas, &quot;Courier New&quot;, Courier, mono, serif; font-size: 12px; background-color: rgb(231, 229, 220); width: 849.412px; overflow-x: auto; overflow-y: hidden; position: relative; color: rgb(69, 69, 69); margin: 18px 0px !important;\"><div class=\"bar\" style=\"margin: 0px; padding: 0px 0px 0px 45px;\"><div class=\"tools\" style=\"margin: 0px; padding: 3px 8px 10px 10px; font-stretch: normal; font-size: 9px; line-height: normal; font-family: Verdana, Geneva, Arial, Helvetica, sans-serif; color: silver; background-color: rgb(248, 248, 248); border-left: 3px solid rgb(108, 226, 108); border-right: 1px solid rgb(231, 229, 220);\"><b>[java]</b>&nbsp;<a href=\"http://blog.csdn.net/qq1115094858/article/details/51873698#\" class=\"ViewSource\" title=\"view plain\" style=\"background-image: url(&quot;images/default/ico_plain.gif&quot;); background-position: left top; background-repeat: no-repeat; color: rgb(202, 12, 22); margin: 0px 10px 0px 0px; padding: 1px; outline: none; border: none; font-size: 9px; display: inline-block; width: 16px; height: 16px; text-indent: -2000px;\">view plain</a><span class=\"tracking-ad\" data-mod=\"popu_168\" style=\"margin: 0px; padding: 0px;\">&nbsp;<a href=\"http://blog.csdn.net/qq1115094858/article/details/51873698#\" class=\"CopyToClipboard\" title=\"copy\" style=\"background-image: url(&quot;images/default/ico_copy.gif&quot;); background-position: left top; background-repeat: no-repeat; color: rgb(202, 12, 22); margin: 0px 10px 0px 0px; padding: 1px; outline: none; border: none; font-size: 9px; display: inline-block; width: 16px; height: 16px; text-indent: -2000px;\">copy</a><div style=\"margin: 0px; padding: 0px; position: absolute; left: 294px; top: 528px; width: 16px; height: 16px; z-index: 99;\"></div></span><span class=\"tracking-ad\" data-mod=\"popu_169\" style=\"margin: 0px; padding: 0px;\"></span></div></div><ol start=\"1\" class=\"dp-j\" style=\"padding: 0px; list-style-position: initial; list-style-image: initial; border-top: none; border-right: 1px solid rgb(231, 229, 220); border-bottom: none; border-left: none; border-image: initial; background-color: rgb(255, 255, 255); color: rgb(92, 92, 92); margin-right: 0px !important; margin-bottom: 1px !important; margin-left: 45px !important;\"><li class=\"alt\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; color: inherit; line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"annotation\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(100, 100, 100); background-color: inherit;\">@Component</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;&nbsp;</span></span></li><li class=\"\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; font-weight: bold; border: none; color: rgb(0, 102, 153); background-color: inherit;\">class</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;WebConfigurer&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; font-weight: bold; border: none; color: rgb(0, 102, 153); background-color: inherit;\">extends</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;WebMvcConfigurerAdapter&nbsp;{&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; color: inherit; line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"annotation\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(100, 100, 100); background-color: inherit;\">@Override</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;&nbsp;</span></span></li><li class=\"\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"keyword\" style=\"margin: 0px; padding: 0px; font-weight: bold; border: none; color: rgb(0, 102, 153); background-color: inherit;\">public</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; font-weight: bold; border: none; color: rgb(0, 102, 153); background-color: inherit;\">void</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;addResourceHandlers(ResourceHandlerRegistry&nbsp;registry)&nbsp;{&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; color: inherit; line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;registry.addResourceHandler(<span class=\"string\" style=\"margin: 0px; padding: 0px; border: none; color: blue; background-color: inherit;\">\"/files/**\"</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">).addResourceLocations(</span><span class=\"string\" style=\"margin: 0px; padding: 0px; border: none; color: blue; background-color: inherit;\">\"file:///var/spring/uploaded_files\"</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">);&nbsp;&nbsp;</span></span></li><li class=\"\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;</span></li><li class=\"alt\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; color: inherit; line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;</span></li><li class=\"\" style=\"margin-left: 40px; list-style: decimal; border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; padding: 0px 3px 0px 10px !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">}&nbsp;&nbsp;</span></li><li></li></ol></div></li></ol>', 'article', null, null, null, null, '1', null, '1', '1', 'bootdo', '2017-09-24 09:15:35', '2017-09-24 09:15:35'), ('111', 'Springmvc提交日期类型参数', null, null, null, '<ol style=\"color: rgb(63, 63, 63); font-family: &quot;microsoft yahei&quot;; font-size: 15px;\"><li><p style=\"margin-bottom: 1.1em; padding: 0px;\">背景介绍&nbsp;<br>在springmvc框架中，前台传入到后台的form会经过springmvc自动封装到pojo类中，后台接受的时候可以在参数内直接接受这个java类。</p></li><li><p style=\"margin-bottom: 1.1em; padding: 0px;\">传参&nbsp;<br>通常情况下，前台的表单的类型诸如int,string等，都会根据pojo中字段的类型自动转换。所以为我们省去了不少麻烦，但很可惜其中不包括日期类型。</p></li><li><p style=\"margin-bottom: 1.1em; padding: 0px;\">原因&nbsp;<br>因为日期的格式多种多样，spring自身不适合对其进行封装。好在spring给出了便捷的方法给我们自己转换数据类型。</p></li><li><p style=\"margin-bottom: 1.1em; padding: 0px;\">具体实现</p></li></ol><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(63, 63, 63); font-family: &quot;microsoft yahei&quot;; font-size: 15px;\">在controller层中，加入以下代码段</p><pre class=\"prettyprint\" name=\"code\" style=\"white-space: nowrap; position: relative; overflow-y: hidden; margin-bottom: 1.1em; font-family: &quot;Source Code Pro&quot;, monospace; padding: 5px 5px 5px 60px; font-size: 14px; line-height: 1.45; background-color: rgba(128, 128, 128, 0.05); border-width: 0px; border-color: rgb(136, 136, 136); border-radius: 0px;\"><code class=\"hljs java has-numbering\" style=\"display: block; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; font-family: &quot;Source Code Pro&quot;, monospace; white-space: pre; word-wrap: normal;\"><span class=\"hljs-annotation\" style=\"color: rgb(155, 133, 157);\">@InitBinder</span>\r\n<span class=\"hljs-keyword\" style=\"color: rgb(0, 0, 136);\">public</span> <span class=\"hljs-keyword\" style=\"color: rgb(0, 0, 136);\">void</span> <span class=\"hljs-title\">initBinder</span>(WebDataBinder binder) {\r\n    SimpleDateFormat dateFormat = <span class=\"hljs-keyword\" style=\"color: rgb(0, 0, 136);\">new</span> SimpleDateFormat(<span class=\"hljs-string\" style=\"color: rgb(0, 136, 0);\">\"yyyy-MM-dd\"</span>);\r\n    dateFormat.setLenient(<span class=\"hljs-keyword\" style=\"color: rgb(0, 0, 136);\">false</span>);\r\n    binder.registerCustomEditor(Date.class, <span class=\"hljs-keyword\" style=\"color: rgb(0, 0, 136);\">new</span> CustomDateEditor(dateFormat, <span class=\"hljs-keyword\" style=\"color: rgb(0, 0, 136);\">true</span>));<span class=\"hljs-comment\" style=\"color: rgb(136, 0, 0);\">//true:允许输入空值，false:不能为空值</span>\r\n}</code><ul class=\"pre-numbering\" style=\"position: absolute; width: 50px; background-color: rgb(238, 238, 238); top: 0px; left: 0px; margin-right: 0px; margin-bottom: 0px; margin-left: 0px; padding: 6px 0px 40px; border-right: 1px solid rgb(221, 221, 221); list-style: none; text-align: right;\"><li style=\"padding: 0px 5px; list-style: none; margin-left: 0px;\">1</li><li style=\"padding: 0px 5px; list-style: none; margin-left: 0px;\">2</li><li style=\"padding: 0px 5px; list-style: none; margin-left: 0px;\">3</li><li style=\"padding: 0px 5px; list-style: none; margin-left: 0px;\">4</li><li style=\"padding: 0px 5px; list-style: none; margin-left: 0px;\">5</li><li style=\"padding: 0px 5px; list-style: none; margin-left: 0px;\">6</li></ul></pre><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(63, 63, 63); font-family: &quot;microsoft yahei&quot;; font-size: 15px;\">可以解决这个问题。但是这个时候Date类型的参数是null的话，还是会报错。采用另外一种方式则更好，为null也不会报错，就是把请求参数封装为一个vo类，在对应的类属性上加上注解，这样</p><pre class=\"prettyprint\" name=\"code\" style=\"white-space: nowrap; position: relative; overflow-y: hidden; margin-bottom: 1.1em; font-family: &quot;Source Code Pro&quot;, monospace; padding: 5px 5px 5px 60px; font-size: 14px; line-height: 1.45; background-color: rgba(128, 128, 128, 0.05); border-width: 0px; border-color: rgb(136, 136, 136); border-radius: 0px;\"><code class=\"hljs java has-numbering\" style=\"display: block; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; font-family: &quot;Source Code Pro&quot;, monospace; white-space: pre; word-wrap: normal;\"><span class=\"hljs-annotation\" style=\"color: rgb(155, 133, 157);\">@DateTimeFormat</span>(iso = ISO.DATE_TIME, pattern = <span class=\"hljs-string\" style=\"color: rgb(0, 136, 0);\">\"w:yyyy\"</span>)\r\n<span class=\"hljs-keyword\" style=\"color: rgb(0, 0, 136);\">private</span> Date startTime;\r\n或者\r\n<span class=\"hljs-annotation\" style=\"color: rgb(155, 133, 157);\">@DateTimeFormat</span>(pattern=<span class=\"hljs-string\" style=\"color: rgb(0, 136, 0);\">\"yyyy-MM-dd HH:mm:ss\"</span>)\r\n<span class=\"hljs-keyword\" style=\"color: rgb(0, 0, 136);\">private</span> Date lastLoginDate;</code><ul class=\"pre-numbering\" style=\"position: absolute; width: 50px; background-color: rgb(238, 238, 238); top: 0px; left: 0px; margin-right: 0px; margin-bottom: 0px; margin-left: 0px; padding: 6px 0px 40px; border-right: 1px solid rgb(221, 221, 221); list-style: none; text-align: right;\"><li style=\"padding: 0px 5px; list-style: none; margin-left: 0px;\">1</li><li style=\"padding: 0px 5px; list-style: none; margin-left: 0px;\">2</li><li style=\"padding: 0px 5px; list-style: none; margin-left: 0px;\">3</li><li style=\"padding: 0px 5px; list-style: none; margin-left: 0px;\">4</li><li style=\"padding: 0px 5px; list-style: none; margin-left: 0px;\">5</li></ul></pre><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(63, 63, 63); font-family: &quot;microsoft yahei&quot;; font-size: 15px;\">另外如果使用验证框架，方法参数这样写(@Valid XxxParam param, BindingResult binding) ，就能直接通过BindingResult得到验证结果了。</p>', 'article', null, null, null, null, '1', null, '1', '1', 'bootdo', '2017-09-25 21:34:51', '2017-09-25 21:34:51'), ('112', ' SpringBoot 在启动时运行代码', null, null, null, '<p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(85, 85, 85); font-family: &quot;microsoft yahei&quot;; font-size: 14px;\">在Spring boot项目的实际开发中，我们有时需要项目服务启动时加载一些数据或预先完成某些动作。为了解决这样的问题，Spring&nbsp;boot 为我们提供了一个方法：通过实现接口 CommandLineRunner 来实现这样的需求。</p><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(85, 85, 85); font-family: &quot;microsoft yahei&quot;; font-size: 14px;\">实现方式：只需要一个类即可，无需其他配置。&nbsp;</p><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(85, 85, 85); font-family: &quot;microsoft yahei&quot;; font-size: 14px;\">实现步骤：</p><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(85, 85, 85); font-family: &quot;microsoft yahei&quot;; font-size: 14px;\">1.创建实现接口 CommandLineRunner 的类 MyStartupRunnerTest</p><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(85, 85, 85); font-family: &quot;microsoft yahei&quot;; font-size: 14px;\"></p><div class=\"dp-highlighter bg_java\" style=\"font-family: Consolas, &quot;Courier New&quot;, Courier, mono, serif; font-size: 12px; background-color: rgb(231, 229, 220); width: 936.531px; overflow-x: auto; overflow-y: hidden; padding-top: 1px; position: relative; border-color: rgb(204, 204, 204); color: rgb(85, 85, 85); margin: 18px 0px !important;\"><div class=\"bar\" style=\"padding-left: 45px;\"><div class=\"tools\" style=\"padding: 3px 8px 10px 10px; font-stretch: normal; font-size: 9px; line-height: normal; font-family: Verdana, Geneva, Arial, Helvetica, sans-serif; color: silver; background-color: rgb(248, 248, 248); border-left: 3px solid rgb(108, 226, 108); border-right: 1px solid rgb(231, 229, 220);\"><strong>[java]</strong>&nbsp;<a target=\"_blank\" href=\"http://blog.csdn.net/mimica247706624/article/details/58596490#\" class=\"ViewSource\" title=\"view plain\" style=\"background-image: url(&quot;images/default/ico_plain.gif&quot;); background-position: left top; background-repeat: no-repeat; border: none; padding: 1px; margin: 0px 10px 0px 0px; font-size: 9px; color: rgb(160, 160, 160); display: inline-block; width: 16px; height: 16px; text-indent: -2000px;\">view plain</a>&nbsp;<a target=\"_blank\" href=\"http://blog.csdn.net/mimica247706624/article/details/58596490#\" class=\"CopyToClipboard\" title=\"copy\" style=\"background-image: url(&quot;images/default/ico_copy.gif&quot;); background-position: left top; background-repeat: no-repeat; border: none; padding: 1px; margin: 0px 10px 0px 0px; font-size: 9px; color: rgb(160, 160, 160); display: inline-block; width: 16px; height: 16px; text-indent: -2000px;\">copy</a><div style=\"position: absolute; left: 559px; top: 655px; width: 18px; height: 18px; z-index: 99;\"></div><div style=\"position: absolute; left: 721px; top: 723px; width: 18px; height: 18px; z-index: 99;\"></div></div></div><ol start=\"1\" class=\"dp-j\" style=\"padding: 0px; border: none; list-style-position: initial; list-style-image: initial; background-color: rgb(255, 255, 255); color: rgb(92, 92, 92); margin-right: 0px !important; margin-bottom: 1px !important; margin-left: 45px !important;\"><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">package</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;com.energy;&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;</span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">import</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;org.springframework.boot.CommandLineRunner;&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">import</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;org.springframework.core.annotation.Order;&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">import</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;org.springframework.stereotype.Component;&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;</span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"comment\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 130, 0); background-color: inherit;\">/**</span>&nbsp;</span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"comment\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 130, 0); background-color: inherit;\">&nbsp;*&nbsp;Created&nbsp;by&nbsp;CavanLiu&nbsp;on&nbsp;2017/2/28&nbsp;0028.</span>&nbsp;</span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"comment\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 130, 0); background-color: inherit;\">&nbsp;*/</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"annotation\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(100, 100, 100); background-color: inherit;\">@Component</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"annotation\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(100, 100, 100); background-color: inherit;\">@Order</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">(value=</span><span class=\"number\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(192, 0, 0); background-color: inherit;\">1</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">)</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">public</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">class</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;MyStartupRunnerTest&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">implements</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;CommandLineRunner&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">{&nbsp;&nbsp;</span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"annotation\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(100, 100, 100); background-color: inherit;\">@Override</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">public</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">void</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;run(String...&nbsp;args)&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">throws</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;Exception&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;{&nbsp;&nbsp;</span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;System.out.println(<span class=\"string\" style=\"margin: 0px; padding: 0px; border: none; color: blue; background-color: inherit;\">\"&gt;&gt;&gt;&gt;This&nbsp;is&nbsp;MyStartupRunnerTest&nbsp;Order=1.&nbsp;Only&nbsp;testing&nbsp;CommandLineRunner...&lt;&lt;&lt;&lt;\"</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">);&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;</span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">}&nbsp;&nbsp;</span></li></ol></div><p style=\"margin-bottom: 0px; padding: 0px; color: rgb(85, 85, 85); font-family: Arial; font-size: 14px;\"></p><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(85, 85, 85); font-family: &quot;microsoft yahei&quot;; font-size: 14px;\">2.创建实现接口CommandLineRunner 的类 MyStartupRunnerTest2</p><div class=\"dp-highlighter bg_java\" style=\"font-family: Consolas, &quot;Courier New&quot;, Courier, mono, serif; font-size: 12px; background-color: rgb(231, 229, 220); width: 936.531px; overflow-x: auto; overflow-y: hidden; padding-top: 1px; position: relative; border-color: rgb(204, 204, 204); color: rgb(85, 85, 85); margin: 18px 0px !important;\"><div class=\"bar\" style=\"padding-left: 45px;\"><div class=\"tools\" style=\"padding: 3px 8px 10px 10px; font-stretch: normal; font-size: 9px; line-height: normal; font-family: Verdana, Geneva, Arial, Helvetica, sans-serif; color: silver; background-color: rgb(248, 248, 248); border-left: 3px solid rgb(108, 226, 108); border-right: 1px solid rgb(231, 229, 220);\"><strong>[java]</strong>&nbsp;<a target=\"_blank\" href=\"http://blog.csdn.net/mimica247706624/article/details/58596490#\" class=\"ViewSource\" title=\"view plain\" style=\"background-image: url(&quot;images/default/ico_plain.gif&quot;); background-position: left top; background-repeat: no-repeat; border: none; padding: 1px; margin: 0px 10px 0px 0px; font-size: 9px; color: rgb(160, 160, 160); display: inline-block; width: 16px; height: 16px; text-indent: -2000px;\">view plain</a>&nbsp;<a target=\"_blank\" href=\"http://blog.csdn.net/mimica247706624/article/details/58596490#\" class=\"CopyToClipboard\" title=\"copy\" style=\"background-image: url(&quot;images/default/ico_copy.gif&quot;); background-position: left top; background-repeat: no-repeat; border: none; padding: 1px; margin: 0px 10px 0px 0px; font-size: 9px; color: rgb(160, 160, 160); display: inline-block; width: 16px; height: 16px; text-indent: -2000px;\">copy</a><div style=\"position: absolute; left: 559px; top: 1094px; width: 18px; height: 18px; z-index: 99;\"></div><div style=\"position: absolute; left: 721px; top: 1160px; width: 18px; height: 18px; z-index: 99;\"></div></div></div><ol start=\"1\" class=\"dp-j\" style=\"padding: 0px; border: none; list-style-position: initial; list-style-image: initial; background-color: rgb(255, 255, 255); color: rgb(92, 92, 92); margin-right: 0px !important; margin-bottom: 1px !important; margin-left: 45px !important;\"><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">package</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;com.energy;&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;</span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">import</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;org.springframework.boot.CommandLineRunner;&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">import</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;org.springframework.core.annotation.Order;&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">import</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;org.springframework.stereotype.Component;&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;</span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"comment\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 130, 0); background-color: inherit;\">/**</span>&nbsp;</span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"comment\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 130, 0); background-color: inherit;\">&nbsp;*&nbsp;Created&nbsp;by&nbsp;CavanLiu&nbsp;on&nbsp;2017/2/28&nbsp;0028.</span>&nbsp;</span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"comment\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 130, 0); background-color: inherit;\">&nbsp;*/</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"annotation\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(100, 100, 100); background-color: inherit;\">@Component</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"annotation\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(100, 100, 100); background-color: inherit;\">@Order</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">(value=</span><span class=\"number\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(192, 0, 0); background-color: inherit;\">2</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">)</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">public</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">class</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;MyStartupRunnerTest2&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">implements</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;CommandLineRunner&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">{&nbsp;&nbsp;</span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"annotation\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(100, 100, 100); background-color: inherit;\">@Override</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;&nbsp;</span></span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">public</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">void</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;run(String...&nbsp;args)&nbsp;</span><span class=\"keyword\" style=\"margin: 0px; padding: 0px; border: none; color: rgb(0, 102, 153); background-color: inherit; font-weight: bold;\">throws</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&nbsp;Exception&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;{&nbsp;&nbsp;</span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;System.out.println(<span class=\"string\" style=\"margin: 0px; padding: 0px; border: none; color: blue; background-color: inherit;\">\"&gt;&gt;&gt;&gt;This&nbsp;is&nbsp;MyStartupRunnerTest&nbsp;Order=2.&nbsp;Only&nbsp;testing&nbsp;CommandLineRunner...&lt;&lt;&lt;&lt;\"</span><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">);&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;</span></li><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">}&nbsp;&nbsp;</span></li></ol></div><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(85, 85, 85); font-family: &quot;microsoft yahei&quot;; font-size: 14px;\">3.启动Spring boot后查看控制台输出信息，如下所示：</p><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(85, 85, 85); font-family: &quot;microsoft yahei&quot;; font-size: 14px;\"></p><div class=\"dp-highlighter bg_plain\" style=\"font-family: Consolas, &quot;Courier New&quot;, Courier, mono, serif; font-size: 12px; background-color: rgb(231, 229, 220); width: 936.531px; overflow-x: auto; overflow-y: hidden; padding-top: 1px; position: relative; border-color: rgb(204, 204, 204); color: rgb(85, 85, 85); margin: 18px 0px !important;\"><div class=\"bar\" style=\"padding-left: 45px;\"><div class=\"tools\" style=\"padding: 3px 8px 10px 10px; font-stretch: normal; font-size: 9px; line-height: normal; font-family: Verdana, Geneva, Arial, Helvetica, sans-serif; color: silver; background-color: rgb(248, 248, 248); border-left: 3px solid rgb(108, 226, 108); border-right: 1px solid rgb(231, 229, 220);\"><strong>[plain]</strong>&nbsp;<a target=\"_blank\" href=\"http://blog.csdn.net/mimica247706624/article/details/58596490#\" class=\"ViewSource\" title=\"view plain\" style=\"background-image: url(&quot;images/default/ico_plain.gif&quot;); background-position: left top; background-repeat: no-repeat; border: none; padding: 1px; margin: 0px 10px 0px 0px; font-size: 9px; color: rgb(160, 160, 160); display: inline-block; width: 16px; height: 16px; text-indent: -2000px;\">view plain</a>&nbsp;<a target=\"_blank\" href=\"http://blog.csdn.net/mimica247706624/article/details/58596490#\" class=\"CopyToClipboard\" title=\"copy\" style=\"background-image: url(&quot;images/default/ico_copy.gif&quot;); background-position: left top; background-repeat: no-repeat; border: none; padding: 1px; margin: 0px 10px 0px 0px; font-size: 9px; color: rgb(160, 160, 160); display: inline-block; width: 16px; height: 16px; text-indent: -2000px;\">copy</a><div style=\"position: absolute; left: 563px; top: 1532px; width: 18px; height: 18px; z-index: 99;\"></div><div style=\"position: absolute; left: 725px; top: 1597px; width: 18px; height: 18px; z-index: 99;\"></div></div></div><ol start=\"1\" style=\"padding: 0px; border: none; list-style-position: initial; list-style-image: initial; background-color: rgb(255, 255, 255); color: rgb(92, 92, 92); margin-right: 0px !important; margin-bottom: 1px !important; margin-left: 45px !important;\"><li class=\"alt\" style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; color: inherit; line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\"><span style=\"margin: 0px; padding: 0px; border: none; background-color: inherit;\">&gt;&gt;&gt;&gt;This&nbsp;is&nbsp;MyStartupRunnerTest&nbsp;Order=1.&nbsp;Only&nbsp;testing&nbsp;CommandLineRunner...&lt;&lt;&lt;&lt;&nbsp;&nbsp;</span></span></li><li style=\"border-top: none; border-right: none; border-bottom: none; border-left: 3px solid rgb(108, 226, 108); border-image: initial; list-style-type: decimal-leading-zero; list-style-image: initial; background-color: rgb(248, 248, 248); line-height: 18px; margin: 0px !important; padding: 0px 3px 0px 10px !important; list-style-position: outside !important;\"><span style=\"margin: 0px; padding: 0px; border: none; color: black; background-color: inherit;\">&gt;&gt;&gt;&gt;This&nbsp;is&nbsp;MyStartupRunnerTest2&nbsp;Order=2.&nbsp;Only&nbsp;testing&nbsp;CommandLineRunner...&lt;&lt;&lt;&lt;&nbsp;&nbsp;</span></li></ol></div><p style=\"margin-bottom: 0px; padding: 0px; color: rgb(85, 85, 85); font-family: Arial; font-size: 14px;\"></p><p style=\"margin-bottom: 1.1em; padding: 0px; color: rgb(85, 85, 85); font-family: &quot;microsoft yahei&quot;; font-size: 14px;\">4.Application启动类代码略。</p><p><span style=\"color: rgb(85, 85, 85); font-family: Arial; font-size: 14px;\">说明：CommandLineRunner接口的运行顺序是依据@Order注解的value由小到大执行，即value值越小优先级越高。</span><br></p>', 'article', null, null, null, null, '1', null, '1', '1', 'bootdo', '2017-09-26 15:18:15', '2017-09-26 15:18:15'), ('115', 'communication', null, null, null, '<h2 style=\"color: rgb(103, 106, 108);\"><span style=\"font-family: Times; font-size: 17.5px; font-weight: bold;\"><a href=\"https://jq.qq.com/?_wv=1027&amp;k=5EfMNFL\" target=\"_blank\" style=\"color: rgb(42, 100, 150); text-decoration-line: underline; outline: 0px;\">qq群 669039323</a></span></h2>', null, null, 'communication', null, null, '1', null, '0', '1', 'bootdo', '2017-09-30 14:43:30', '2017-09-30 14:43:30'), ('116', 'ablout', null, null, null, '<h1 style=\"box-sizing: inherit; font-size: 28px; font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-weight: bold; line-height: 1.33em; color: rgb(0, 0, 0); min-height: 1rem; -webkit-font-smoothing: antialiased; cursor: text; position: relative; margin-top: 0px !important;\">BootDo 面向学习型的开源框架</h1><h2 style=\"box-sizing: inherit; font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-weight: bold; line-height: 1.33em; color: rgb(0, 0, 0); margin-top: 20px; font-size: 24px; padding-bottom: 0.3em; -webkit-font-smoothing: antialiased; cursor: text; position: relative; border-bottom: 1px solid rgb(204, 204, 204);\"><a id=\"平台简介\" class=\"anchor\" href=\"https://gitee.com/lcg0124/bootdo#%E5%B9%B3%E5%8F%B0%E7%AE%80%E4%BB%8B\" style=\"box-sizing: inherit; color: rgb(9, 94, 171); word-wrap: break-word; display: block; padding-left: 30px; margin-left: -20px; position: absolute; top: 0px; left: 0px; bottom: 0px; outline: none;\"></a>平台简介</h2><p style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 25px; word-break: break-word; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\">BootDo是高效率，低封装，面向学习型，面向微服的<strong style=\"box-sizing: inherit;\">开源</strong>Java EE开发框架。</p><p style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 25px; word-break: break-word; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\">BootDo是在SpringBoot基础上搭建的一个Java基础开发平台，MyBatis为数据访问层，ApacheShiro为权限授权层，Ehcahe对常用数据进行缓存。</p><p style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 25px; word-break: break-word; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\">BootDo主要定位于后台管理系统学习交流，已内置后台管理系统的基础功能和高效的<strong style=\"box-sizing: inherit;\">代码生成</strong>工具， 包括：系统权限组件、数据权限组件、数据字典组件、核心工具组件、视图操作组件、工作流组件、代码生成等。 前端界面风格采用了结构简单、性能优良、页面美观大气的Twitter Bootstrap页面展示框架。 采用分层设计、双重验证、提交数据安全编码、密码加密、访问验证、数据权限验证。 使用Maven做项目管理，提高项目的易开发性、扩展性。</p><p style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 25px; word-break: break-word; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\">BootDo目前包括以下四大模块，系统管理（SYS）模块、 内容管理（CMS）模块、在线办公（OA）模块、代码生成（GEN）模块。&nbsp;<strong style=\"box-sizing: inherit;\">系统管理模块</strong>&nbsp;，包括企业组织架构（用户管理、机构管理、区域管理）、 菜单管理、角色权限管理、字典管理等功能；&nbsp;<strong style=\"box-sizing: inherit;\">内容管理模块</strong>&nbsp;，包括内容管理（文章、链接），栏目管理、站点管理、 公共留言、文件管理、前端网站展示等功能；&nbsp;<strong style=\"box-sizing: inherit;\">在线办公模块</strong>&nbsp;，提供简单的请假流程实例；<strong style=\"box-sizing: inherit;\">代码生成模块</strong>&nbsp;，完成重复的工作。</p><p style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 25px; word-break: break-word; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\">BootDo 提供了常用工具进行封装，包括日志工具、缓存工具、服务器端验证、数据字典、当前组织机构数据 （用户、机构、区域）以及其它常用小工具等。另外还提供一个强大的在线&nbsp;<strong style=\"box-sizing: inherit;\">代码生成</strong>&nbsp;工具。</p><h2 style=\"box-sizing: inherit; font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-weight: bold; line-height: 1.33em; color: rgb(0, 0, 0); margin-top: 20px; font-size: 24px; padding-bottom: 0.3em; -webkit-font-smoothing: antialiased; cursor: text; position: relative; border-bottom: 1px solid rgb(204, 204, 204);\"><a id=\"内置功能\" class=\"anchor\" href=\"https://gitee.com/lcg0124/bootdo#%E5%86%85%E7%BD%AE%E5%8A%9F%E8%83%BD\" style=\"box-sizing: inherit; color: rgb(9, 94, 171); word-wrap: break-word; display: block; padding-left: 30px; margin-left: -20px; position: absolute; top: 0px; left: 0px; bottom: 0px; outline: none;\"></a>内置功能</h2><ol class=\"task-list\" style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 24px; padding-left: 30px; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\"><li style=\"box-sizing: inherit; list-style-type: decimal;\">用户管理：用户是系统操作者，该功能主要完成系统用户配置。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">机构管理：配置系统组织机构（公司、部门、小组），树结构展现，可随意调整上下级。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">区域管理：系统城市区域模型，如：国家、省市、地市、区县的维护。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">菜单管理：配置系统菜单，操作权限，按钮权限标识等。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">角色管理：角色菜单权限分配、设置角色按机构进行数据范围权限划分。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">字典管理：对系统中经常使用的一些较为固定的数据进行维护，如：是否、男女、类别、级别等。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">操作日志：系统正常操作日志记录和查询；系统异常信息日志记录和查询。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">连接池监视：监视当期系统数据库连接池状态，可进行分析SQL找出系统性能瓶颈。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">工作流引擎：实现业务工单流转、在线流程设计器。</li></ol><h2 style=\"box-sizing: inherit; font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-weight: bold; line-height: 1.33em; color: rgb(0, 0, 0); margin-top: 20px; font-size: 24px; padding-bottom: 0.3em; -webkit-font-smoothing: antialiased; cursor: text; position: relative; border-bottom: 1px solid rgb(204, 204, 204);\"><a id=\"技术选型\" class=\"anchor\" href=\"https://gitee.com/lcg0124/bootdo#%E6%8A%80%E6%9C%AF%E9%80%89%E5%9E%8B\" style=\"box-sizing: inherit; color: rgb(9, 94, 171); word-wrap: break-word; display: block; padding-left: 30px; margin-left: -20px; position: absolute; top: 0px; left: 0px; bottom: 0px; outline: none;\"></a>技术选型</h2><p style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 25px; word-break: break-word; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\">1、后端</p><ul class=\"task-list\" style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 24px; padding-left: 30px; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\"><li style=\"box-sizing: inherit; list-style-type: initial;\">核心框架：Spring Boot</li><li style=\"box-sizing: inherit; list-style-type: initial;\">安全框架：Apache Shiro</li><li style=\"box-sizing: inherit; list-style-type: initial;\">模板引擎：Thymeleaf</li><li style=\"box-sizing: inherit; list-style-type: initial;\">持久层框架：MyBatis</li><li style=\"box-sizing: inherit; list-style-type: initial;\">数据库连接池：Alibaba Druid</li><li style=\"box-sizing: inherit; list-style-type: initial;\">缓存框架：Ehcache 、Redis</li><li style=\"box-sizing: inherit; list-style-type: initial;\">日志管理：SLF4J</li><li style=\"box-sizing: inherit; list-style-type: initial;\">工具类：Apache Commons、Jackson 、Xstream 1.4、Dozer 5.3、POI 3.9</li></ul><p style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 25px; word-break: break-word; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\">2、前端</p><ul class=\"task-list\" style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 24px; padding-left: 30px; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\"><li style=\"box-sizing: inherit; list-style-type: initial;\">JS框架：jQuery</li><li style=\"box-sizing: inherit; list-style-type: initial;\">客户端验证：JQuery Validation</li><li style=\"box-sizing: inherit; list-style-type: initial;\">富文本在线编辑：summernote</li><li style=\"box-sizing: inherit; list-style-type: initial;\">在线文件管理：CKFinder</li><li style=\"box-sizing: inherit; list-style-type: initial;\">数据表格：bootstrapTable</li><li style=\"box-sizing: inherit; list-style-type: initial;\">弹出层：layer</li><li style=\"box-sizing: inherit; list-style-type: initial;\">树结构控件：jsTree</li></ul><p style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 25px; word-break: break-word; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\">4、平台</p><ul class=\"task-list\" style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 24px; padding-left: 30px; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\"><li style=\"box-sizing: inherit; list-style-type: initial;\">服务器中间件：SpringBoot内置</li><li style=\"box-sizing: inherit; list-style-type: initial;\">数据库支持：目前仅提供MySql数据库的支持，但不限于数据库，平台留有其它数据库支持接口， 你可以很方便的更改为其它数据库，如：SqlServer 2008、MySql 5.5、H2等</li><li style=\"box-sizing: inherit; list-style-type: initial;\">开发环境：Java、Eclipse Java EE 、Maven 、Git</li></ul><h2 style=\"box-sizing: inherit; font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-weight: bold; line-height: 1.33em; color: rgb(0, 0, 0); margin-top: 20px; font-size: 24px; padding-bottom: 0.3em; -webkit-font-smoothing: antialiased; cursor: text; position: relative; border-bottom: 1px solid rgb(204, 204, 204);\"><a id=\"安全考虑\" class=\"anchor\" href=\"https://gitee.com/lcg0124/bootdo#%E5%AE%89%E5%85%A8%E8%80%83%E8%99%91\" style=\"box-sizing: inherit; color: rgb(9, 94, 171); word-wrap: break-word; display: block; padding-left: 30px; margin-left: -20px; position: absolute; top: 0px; left: 0px; bottom: 0px; outline: none;\"></a>安全考虑</h2><ol class=\"task-list\" style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 24px; padding-left: 30px; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\"><li style=\"box-sizing: inherit; list-style-type: decimal;\">开发语言：系统采用Java 语言开发，具有卓越的通用性、高效性、平台移植性和安全性。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">分层设计：（数据库层，数据访问层，业务逻辑层，展示层）层次清楚，低耦合，各层必须通过接口才能接入并进行参数校验（如：在展示层不可直接操作数据库），保证数据操作的安全。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">双重验证：用户表单提交双验证：包括服务器端验证及客户端验证，防止用户通过浏览器恶意修改（如不可写文本域、隐藏变量篡改、上传非法文件等），跳过客户端验证操作数据库。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">安全编码：用户表单提交所有数据，在服务器端都进行安全编码，防止用户提交非法脚本及SQL注入获取敏感数据等，确保数据安全。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">密码加密：登录用户密码进行SHA1散列加密，此加密方法是不可逆的。保证密文泄露后的安全问题。</li><li style=\"box-sizing: inherit; list-style-type: decimal;\">强制访问：系统对所有管理端链接都进行用户身份权限验证，防止用户直接填写url进行访问。</li></ol><h2 style=\"box-sizing: inherit; font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-weight: bold; line-height: 1.33em; color: rgb(0, 0, 0); margin-top: 20px; font-size: 24px; padding-bottom: 0.3em; -webkit-font-smoothing: antialiased; cursor: text; position: relative; border-bottom: 1px solid rgb(204, 204, 204);\"><a id=\"演示地址\" class=\"anchor\" href=\"https://gitee.com/lcg0124/bootdo#%E6%BC%94%E7%A4%BA%E5%9C%B0%E5%9D%80\" style=\"box-sizing: inherit; color: rgb(9, 94, 171); word-wrap: break-word; display: block; padding-left: 30px; margin-left: -20px; position: absolute; top: 0px; left: 0px; bottom: 0px; outline: none;\"></a>演示地址</h2><h6 style=\"box-sizing: inherit; font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-weight: bold; color: rgb(119, 119, 119); margin-top: 20px; font-size: 14px; -webkit-font-smoothing: antialiased; cursor: text; position: relative;\"><a id=\"布嘟开源wwwbootdocom\" class=\"anchor\" href=\"https://gitee.com/lcg0124/bootdo#%E5%B8%83%E5%98%9F%E5%BC%80%E6%BA%90wwwbootdocom\" style=\"box-sizing: inherit; color: rgb(9, 94, 171); word-wrap: break-word; display: block; padding-left: 30px; margin-left: -20px; position: absolute; top: 0px; left: 0px; bottom: 0px; outline: none;\"></a>布嘟开源<a href=\"http://www.bootdo.com./blog\" style=\"box-sizing: inherit; color: rgb(9, 94, 171); word-wrap: break-word;\">www.bootdo.com</a></h6><h2 style=\"box-sizing: inherit; font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-weight: bold; line-height: 1.33em; color: rgb(0, 0, 0); margin-top: 20px; font-size: 24px; padding-bottom: 0.3em; -webkit-font-smoothing: antialiased; cursor: text; position: relative; border-bottom: 1px solid rgb(204, 204, 204);\"><a id=\"交流反馈\" class=\"anchor\" href=\"https://gitee.com/lcg0124/bootdo#%E4%BA%A4%E6%B5%81%E5%8F%8D%E9%A6%88\" style=\"box-sizing: inherit; color: rgb(9, 94, 171); word-wrap: break-word; display: block; padding-left: 30px; margin-left: -20px; position: absolute; top: 0px; left: 0px; bottom: 0px; outline: none;\"></a>交流反馈</h2><h2 style=\"box-sizing: inherit; font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-weight: bold; line-height: 1.33em; color: rgb(0, 0, 0); margin-top: 20px; font-size: 24px; padding-bottom: 0.3em; -webkit-font-smoothing: antialiased; cursor: text; position: relative; border-bottom: 1px solid rgb(204, 204, 204);\"><a id=\"qq群-669039323\" class=\"anchor\" href=\"https://gitee.com/lcg0124/bootdo#qq%E7%BE%A4-669039323\" style=\"box-sizing: inherit; color: rgb(9, 94, 171); word-wrap: break-word; display: block; padding-left: 30px; margin-left: -20px; position: absolute; top: 0px; left: 0px; bottom: 0px; outline: none;\"></a>QQ群 669039323</h2><h2 style=\"box-sizing: inherit; font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-weight: bold; line-height: 1.33em; color: rgb(0, 0, 0); margin-top: 20px; font-size: 24px; padding-bottom: 0.3em; -webkit-font-smoothing: antialiased; cursor: text; position: relative; border-bottom: 1px solid rgb(204, 204, 204);\"><a id=\"版权声明\" class=\"anchor\" href=\"https://gitee.com/lcg0124/bootdo#%E7%89%88%E6%9D%83%E5%A3%B0%E6%98%8E\" style=\"box-sizing: inherit; color: rgb(9, 94, 171); word-wrap: break-word; display: block; padding-left: 30px; margin-left: -20px; position: absolute; top: 0px; left: 0px; bottom: 0px; outline: none;\"></a>版权声明</h2><p style=\"box-sizing: inherit; margin-bottom: 15px; line-height: 25px; word-break: break-word; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px;\">本软件使用&nbsp;<a href=\"http://www.apache.org/licenses/LICENSE-2.0\" style=\"box-sizing: inherit; color: rgb(9, 94, 171); word-wrap: break-word;\">Apache License 2.0</a>&nbsp;协议，请严格遵照协议内容</p><ul class=\"task-list\" style=\"box-sizing: inherit; line-height: 24px; padding-left: 30px; color: rgb(64, 72, 91); font-family: -apple-system, BlinkMacSystemFont, &quot;Segoe UI&quot;, Helvetica, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Liberation Sans&quot;, &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, &quot;Hiragino Sans GB&quot;, &quot;Wenquanyi Micro Hei&quot;, &quot;WenQuanYi Zen Hei&quot;, &quot;ST Heiti&quot;, SimHei, &quot;WenQuanYi Zen Hei Sharp&quot;, sans-serif; font-size: 15px; margin-bottom: 0px !important;\"><li class=\"task-list-item\" style=\"box-sizing: inherit; list-style-type: initial;\"><input type=\"checkbox\" class=\"task-list-item-checkbox\" checked=\"\" disabled=\"\" style=\"margin-top: 0px; cursor: default; transition: border 0.2s linear, box-shadow 0.2s linear; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px inset; vertical-align: middle;\">&nbsp;注：已上内容为整体规化，部分功能还在实现中</li></ul>', null, null, 'about', null, null, '1', null, '0', '1', 'bootdo', '2017-09-30 14:43:09', '2017-09-30 14:43:09');
INSERT INTO `blog_content` VALUES ('117', '页面加载速度优化建议', null, null, null, '<p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\"><span style=\"font-weight: 700;\">1、合并Js文件和CSS</span></p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\">将JS代码和CSS样式分别合并到一个共享的文件，这样不仅能简化代码，而且在执行JS文件的时候，如果JS文件比较多，就需要进行多次“Get”请求，延长加载速度，将JS文件合并在一起后，自然就减少了Get请求次数，提高了加载速度。</p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\"><span style=\"font-weight: 700;\">2、Sprites图片技术</span></p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\">Spriting是一种网页图片应用处理方式，它是将一个页面涉及到的所有零星图片都包含到一张大图中去，然后利用CSS技术展现出来。这样一来，当访问该页面时，载入的图片就不会像以前那样一幅一幅地慢慢显示出来了，可以减少了整个网页的图片大小，并且利用CSSSprites能很好地减少网页的http请求，从而大大的提高页面的性能。CSSSprites在国内很多人叫css精灵，很早就有了，在很多大型网站都有用到，特别是一些所有页面都存在的图标用得比较多，很好的提升加载速度。</p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\"><span style=\"font-weight: 700;\">3、压缩文本和图片</span></p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\">压缩技术如gzip可以有效减少页面加载的时间。包括HTML，XML，JSON(JavaScript对象符号)，JavaScript和CSS等，压缩率都可以在大小70%左右。文本压缩用得比较多，一般直接在空间开启就行，而图片的压缩就比较随意，很多都是直接上传，其实还有很大的压缩空间。</p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\"><span style=\"font-weight: 700;\">4、延迟显示可见区域外的内容</span></p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\">为了确保用户可以更快地看见可见区域的网页可以延迟加载或展现可见区域外的内容，为了避免页面变形，可以使用占位符标签制定正确的高度和宽度。比如WP的jQueryImage LazyLoad插件就可以在用户停留在第一屏的时候，不加载任何第一屏以下的图片信息，只有当用户把鼠标往下滚动的时候，这些图片才开始加载。这样很明显提升可见区域的加载速度，提高用户体验。</p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\"><span style=\"font-weight: 700;\">5、确保功能图片优先加载</span></p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\">网站主要考虑可用性的重要性，一个功能按钮要提前加载出来，用户进入下载页，一个只需要8s时间的下载花了5s在等待、寻找下载按钮图片，谁能忍受?</p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\"><span style=\"font-weight: 700;\">6、重新布置Call-to-Action按钮</span></p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\">其实这个和上面一条是差不多的，都是从用户体验速度着手，跳过了网页的整体加载速度。速度没变，只是让一些行为按钮提前，Call-to-Action按钮一般习惯设计在页面底部，这样的习惯对于用户来说并不总是好的，购买用户需要等到最下面加载出来才能点击下一步操作。可以调整CTA按钮的位置或使用滑动的图片按钮。很多大型购物网站的加入购物车就是这种类型。</p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\"><span style=\"font-weight: 700;\">7、图片格式优化</span></p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\">不恰当的图像格式是一种极为常见的减慢加载速度的罪魁祸首。正确的图片格式可以让图片缩小数倍，如果保存为最佳格式。可以节省大量带宽，减少处理时间时间，大大加快页面加载速度，这是一种很常见的做法。</p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\"><span style=\"font-weight: 700;\">8、使用 Progressive JPEGs</span></p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\">ProgressiveJPEGs图片是JPEG格式的一个特殊变种，名为“高级JPEG”。在创建高级JPEG文件时，数据是这样安排的：在装入图像时，开始只显示一个模糊的图像，随着数据的装入，图像逐步变得清晰。它相当于交织的GIF格式的图片。高级JPEG主要是考虑到使用调制解调器的慢速网络而设计的，快速网络的使用者通常不会体会到它和正常JPEG格式图片的区别。对于网速比较慢的用户，这无疑有很好的体验。</p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\"><span style=\"font-weight: 700;\">9、精简代码</span></p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\">这个可以说是最直接的一个方法，也是用得比较多的，对网页代码进行瘦身，删除不必要的沉冗代码，比如不必要的空格、换行符、注释等，包括JS代码中的无用代码也需要清除。其中对于注释代码的清除可能有些人存在误区，甚至有的在里面堆砌关键词。</p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\"><span style=\"font-weight: 700;\">10、延迟加载和执行非必要脚本</span></p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\">网页中有很多脚本是在页面完全加载完前都不需要执行的，可以延迟加载和执行非必要脚本。这些脚本可以在onload事件之后执行，避免对网页上重要内容的呈现造成影响。这些脚本可能是你自己网页的甲苯，往往更多的是一些第三方脚本，这样的有很多，比如评论、广告、智能推荐、百度云图、分享等等，这些完全可以等主体内容加载完后再执行。</p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\"><span style=\"font-weight: 700;\">11、使用AJAX</span></p><p style=\"margin-bottom: 24px; color: rgb(14, 14, 14); font-family: Arial, &quot;Hiragino Sans GB&quot;, 冬青黑, &quot;Microsoft YaHei&quot;, 微软雅黑, SimSun, 宋体, Helvetica, Tahoma, &quot;Arial sans-serif&quot;; font-size: 16px; text-align: justify;\">AJAX即“Asynchronous Javascript +XML“，是指一种创建交互式网页应用的网页开发技术。通过在后台与服务器进行少量数据交换，AJAX可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下，对网页的某部分进行更新。传统的网页(不使用AJAX)如果需要更新内容，必须重载整个网页面。</p>', null, null, '', null, null, '1', null, '0', '1', 'bootdo', '2017-09-30 16:13:35', '2017-09-30 16:13:35'), ('118', 'elementUI select组件使用详解', null, null, null, '<article style=\"padding: 20px 0px; border-top: 1px solid rgb(228, 235, 244); border-left: 1px solid rgb(228, 235, 244); border-right: 1px solid rgb(228, 235, 244); color: rgb(51, 51, 51); font-family: &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, SimHei, Arial, SimSun; font-size: 16px;\"><div id=\"article_content\" class=\"article_content csdn-tracking-statistics\" data-mod=\"popu_307\" data-dsm=\"post\" style=\"margin: 0px 0px 50px; padding: 20px 30px 0px; color: rgb(69, 69, 69); overflow: hidden;\"><div class=\"markdown_views\" style=\"margin: 0px; padding: 0px; font-family: &quot;microsoft yahei&quot;; font-size: 15px; color: rgb(63, 63, 63);\"><h1 id=\"elementui-select组件使用详解\" style=\"margin-top: 0.8em; margin-bottom: 0.8em; font-size: 2.6em; font-family: inherit; padding: 0px;\">elementUI select组件使用详解</h1><ul style=\"margin-right: 0px; margin-bottom: 0px; margin-left: 0px; padding: 0px; list-style-position: initial; list-style-image: initial;\"><li style=\"margin: 0px 0px 0px 40px; padding: 0px; list-style: disc;\"><strong>动态生成option选项</strong></li><li style=\"margin: 0px 0px 0px 40px; padding: 0px; list-style: disc;\"><strong>option选项绑定对应的文本值和value值</strong></li><li style=\"margin: 0px 0px 0px 40px; padding: 0px; list-style: disc;\"><strong>作为表单项目，新增、编辑功能</strong></li><li style=\"margin: 0px 0px 0px 40px; padding: 0px; list-style: disc;\"><strong>对选项改变后触发相关事件</strong></li></ul><pre class=\"prettyprint\" style=\"font-family: &quot;Source Code Pro&quot;, monospace; font-size: 14px; white-space: nowrap; padding: 5px 5px 5px 60px; margin-bottom: 1.1em; line-height: 1.45; background-color: rgba(128, 128, 128, 0.05); border-color: rgba(128, 128, 128, 0.075); border-radius: 0px; position: relative; overflow-y: hidden;\"><code class=\"hljs lasso has-numbering\" style=\"font-family: &quot;Source Code Pro&quot;, monospace; white-space: pre; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; display: block; word-wrap: normal;\"><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>div id<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"app\"</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n    <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-form</span> :model<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"form\"</span>  ref<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"form\"</span> label<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-width</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"100px\"</span> class<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"demo-ruleForm\"</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n        <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-form</span><span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-item</span> label<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"姓名选择\"</span> prop<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"typeId\"</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n            <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-select</span> v<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-model</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"form.typeId\"</span> placeholder<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"请选择\"</span> @change<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"change\"</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n                <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-option</span> v<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-for</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"item in items\"</span> :label<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"item.name\"</span> :value<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"item.id\"</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;&lt;</span>/el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-option</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n            <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>/el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-select</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n        <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>/el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-form</span><span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-item</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n        <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-form</span><span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-item</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n            <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-button</span> <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">type</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"primary\"</span> @click<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"add()\"</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>新增<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>/el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-button</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n            <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-button</span> <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">type</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"primary\"</span> @click<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"edit()\"</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>编辑<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>/el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-button</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n            <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-button</span> @click<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">=</span><span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"cancel()\"</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>取消<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>/el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-button</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n        <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>/el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-form</span><span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-item</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n    <span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>/el<span class=\"hljs-attribute\" style=\"margin: 0px; padding: 0px;\">-form</span><span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span>\r\n<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&lt;</span>/div<span class=\"hljs-subst\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 0);\">&gt;</span></code><ul class=\"pre-numbering\" style=\"margin-right: 0px; margin-bottom: 0px; margin-left: 0px; padding: 6px 0px 40px; list-style: none; position: absolute; width: 50px; background-color: rgb(238, 238, 238); top: 0px; left: 0px; border-right: 1px solid rgb(221, 221, 221); text-align: right;\"><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">1</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">2</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">3</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">4</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">5</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">6</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">7</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">8</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">9</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">10</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">11</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">12</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">13</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">14</li></ul></pre><pre class=\"prettyprint\" style=\"font-family: &quot;Source Code Pro&quot;, monospace; font-size: 14px; white-space: nowrap; padding: 5px 5px 5px 60px; margin-bottom: 1.1em; line-height: 1.45; background-color: rgba(128, 128, 128, 0.05); border-color: rgba(128, 128, 128, 0.075); border-radius: 0px; position: relative; overflow-y: hidden;\"><code class=\"hljs xml has-numbering\" style=\"font-family: &quot;Source Code Pro&quot;, monospace; white-space: pre; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; display: block; word-wrap: normal;\"><span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">script</span>&gt;</span><span class=\"javascript\" style=\"margin: 0px; padding: 0px;\">\r\n    <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">var</span> vm = <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">new</span> Vue({\r\n        el:<span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"#app\"</span>,\r\n        mounted(){\r\n            <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">this</span>.getData();\r\n        },\r\n        data:{\r\n            form:{\r\n                typeId:<span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\'\'</span>\r\n            },\r\n            items:[],\r\n            datas:[{name:<span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"senbo\"</span>,id:<span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\'1\'</span>},{name:<span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"muse\"</span>,id:<span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\'2\'</span>},{name:<span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"bobo\"</span>,id:<span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\'3\'</span>}]\r\n        },\r\n        methods:{\r\n            getData:<span class=\"hljs-function\" style=\"margin: 0px; padding: 0px;\"><span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">function</span><span class=\"hljs-params\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">()</span>{</span>\r\n                <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">this</span>.items = <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">this</span>.datas; \r\n\r\n            },\r\n            add:<span class=\"hljs-function\" style=\"margin: 0px; padding: 0px;\"><span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">function</span><span class=\"hljs-params\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">()</span>{</span>\r\n                <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">this</span>.form.typeId = <span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"\"</span>;\r\n            },\r\n            cancel(){\r\n                 <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">this</span>.form.typeId = <span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"\"</span>;   \r\n            },\r\n            change:<span class=\"hljs-function\" style=\"margin: 0px; padding: 0px;\"><span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">function</span><span class=\"hljs-params\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">()</span>{</span>\r\n                console.log(<span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">this</span>.form.typeId)\r\n            },\r\n            edit:<span class=\"hljs-function\" style=\"margin: 0px; padding: 0px;\"><span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">function</span><span class=\"hljs-params\" style=\"margin: 0px; padding: 0px; color: rgb(102, 0, 102);\">()</span>{</span>\r\n                <span class=\"hljs-keyword\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">this</span>.form.typeId =<span class=\"hljs-string\" style=\"margin: 0px; padding: 0px; color: rgb(0, 136, 0);\">\"1\"</span>;\r\n            }\r\n        }\r\n    })\r\n</span><span class=\"hljs-tag\" style=\"margin: 0px; padding: 0px; color: rgb(0, 102, 102);\">&lt;/<span class=\"hljs-title\" style=\"margin: 0px; padding: 0px; color: rgb(0, 0, 136);\">script</span>&gt;</span></code><ul class=\"pre-numbering\" style=\"margin-right: 0px; margin-bottom: 0px; margin-left: 0px; padding: 6px 0px 40px; list-style: none; position: absolute; width: 50px; background-color: rgb(238, 238, 238); top: 0px; left: 0px; border-right: 1px solid rgb(221, 221, 221); text-align: right;\"><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">1</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">2</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">3</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">4</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">5</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">6</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">7</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">8</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">9</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">10</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">11</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">12</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">13</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">14</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">15</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">16</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">17</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">18</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">19</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">20</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">21</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">22</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">23</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">24</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">25</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">26</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">27</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">28</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">29</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">30</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">31</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">32</li><li style=\"margin: 0px; padding: 0px 5px; list-style: none; color: rgb(153, 153, 153);\">33</li></ul></pre></div></div></article><div class=\"article_copyright\" style=\"margin: 0px 0px -20px; padding: 0px 20px 30px; border-bottom: 1px solid rgb(228, 235, 244); border-left: 1px solid rgb(228, 235, 244); border-right: 1px solid rgb(228, 235, 244); font-size: 14px; color: rgb(120, 128, 135); clear: both; overflow: hidden; font-family: &quot;PingFang SC&quot;, &quot;Microsoft YaHei&quot;, SimHei, Arial, SimSun;\">转自http://blog.csdn.net/museions/article/details/77824361</div>', 'article', null, '', null, null, '1', null, '0', '1', 'bootdo', '2017-10-12 10:41:07', '2017-10-12 10:41:07'), ('119', 'Java程序员秋招面经大合集（BAT美团网易小米华为中兴等）', null, null, null, '<h1 class=\"title\" style=\"font-size: 34px; margin-top: 20px; margin-bottom: 0px; font-family: -apple-system, &quot;SF UI Display&quot;, Arial, &quot;PingFang SC&quot;, &quot;Hiragino Sans GB&quot;, &quot;Microsoft YaHei&quot;, &quot;WenQuanYi Micro Hei&quot;, sans-serif; font-weight: 700; line-height: 1.3; color: rgb(51, 51, 51); word-break: break-word !important;\">Java程序员秋招面经大合集（BAT美团网易小米华为中兴等）</h1><div data-note-content=\"\" class=\"show-content\" style=\"color: rgb(47, 47, 47); font-size: 16px; line-height: 1.7; font-family: -apple-system, &quot;SF UI Text&quot;, Arial, &quot;PingFang SC&quot;, &quot;Hiragino Sans GB&quot;, &quot;Microsoft YaHei&quot;, &quot;WenQuanYi Micro Hei&quot;, sans-serif; word-break: break-word !important;\"><blockquote style=\"padding-top: 20px; padding-bottom: 20px; margin-bottom: 25px; font-size: 16px; border-left-width: 6px; border-left-color: rgb(180, 180, 180); background-color: rgb(247, 247, 247); line-height: 30px; word-break: break-word !important;\"><ul style=\"padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">Cvte提前批</li><li style=\"line-height: 30px; margin-bottom: 10px;\">阿里内推</li><li style=\"line-height: 30px; margin-bottom: 10px;\">便利蜂内推</li><li style=\"line-height: 30px; margin-bottom: 10px;\">小米内推</li><li style=\"line-height: 30px; margin-bottom: 10px;\">金山wps内推</li><li style=\"line-height: 30px; margin-bottom: 10px;\">多益网络</li><li style=\"line-height: 30px; margin-bottom: 10px;\">拼多多学霸批</li><li style=\"line-height: 30px; margin-bottom: 10px;\">搜狗校招</li><li style=\"line-height: 30px; margin-bottom: 10px;\">涂鸦移动</li><li style=\"line-height: 30px; margin-bottom: 10px;\">中国电信it研发中心</li><li style=\"line-height: 30px; margin-bottom: 10px;\">中兴</li><li style=\"line-height: 30px; margin-bottom: 10px;\">华为</li><li style=\"line-height: 30px; margin-bottom: 10px;\">苏宁内推</li><li style=\"line-height: 30px; margin-bottom: 10px;\">美团内推</li><li style=\"line-height: 30px; margin-bottom: 10px;\">百度</li><li style=\"line-height: 30px; margin-bottom: 10px;\">腾讯</li><li style=\"line-height: 30px; margin-bottom: 10px;\">招商银行信用卡</li><li style=\"line-height: 30px; margin-bottom: 10px;\">招银网络科技</li><li style=\"line-height: 30px; margin-bottom: 10px;\">网易</li><li style=\"line-height: 30px; margin-bottom: 0px;\">Vivo</li></ul></blockquote><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">Cvte提前批</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（电话）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">介绍你的项目</li><li style=\"line-height: 30px; margin-bottom: 10px;\">加密解密了解么？几种算法，讲一下你了解的</li><li style=\"line-height: 30px; margin-bottom: 10px;\">多线程了解么？什么是线程安全？</li><li style=\"line-height: 30px; margin-bottom: 10px;\">说一个你最熟悉的设计模式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">讲一下你项目中用到了哪些设计模式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Java的hashmap的原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hashmap的线程安全性，什么是线程安全的？如何实现线程安全</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面（视频）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">介绍项目</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Mysql的数据库引擎，区别特点</li><li style=\"line-height: 30px; margin-bottom: 10px;\">设计模式了解？讲一下最熟悉的</li><li style=\"line-height: 30px; margin-bottom: 10px;\">写一个单例模式，答主写的是双检查锁单例，问了为什么用Volatile，synchronize移到方法最外面会怎么样？</li><li style=\"line-height: 30px; margin-bottom: 10px;\">单例模式在你项目里哪些应用？</li><li style=\"line-height: 30px; margin-bottom: 10px;\">数据连接池</li><li style=\"line-height: 30px; margin-bottom: 10px;\">对高负载有了解么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">你意向的技术方向是哪块？（答主回答的高并发，然后面试官说他是做高负载的）</li><li style=\"line-height: 30px; margin-bottom: 10px;\">对高并发有了解么？</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">阿里内推</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（电话）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">听说你有博客，博客里大概有什么内容？</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍，最复杂的表</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hashmap的原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hashmap为什么大小是2的幂次</li><li style=\"line-height: 30px; margin-bottom: 10px;\">介绍一下红黑树</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Arraylist的原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">场景题：设计判断论文抄袭的系统</li><li style=\"line-height: 30px; margin-bottom: 10px;\">堆排序的原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">抽象工厂和工厂方法模式的区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">工厂模式的思想</li><li style=\"line-height: 30px; margin-bottom: 10px;\">object类你知道的方法</li><li style=\"line-height: 30px; margin-bottom: 10px;\">哪里用到了工厂模式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Forward和redirect的区别</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面（视频）</h2><p style=\"margin-bottom: 25px; word-break: break-word !important;\">1， 自我介绍<br>2， 项目介绍<br>3， 项目架构<br>4， 项目难点<br>5， Synchronize关键字为什么jdk1.5后效率提高了<br>6， 线程池的使用时的注意事项<br>7， Spring中autowire和resourse关键字的区别<br>8， Hashmap的原理<br>9， Hashmap的大小为什么指定为2的幂次<br>10， 讲一下线程状态转移图<br>11， 消息队列了解么<br>12， 分布式了解么</p><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">便利蜂内推</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（电话）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">volatile和synchronized</li><li style=\"line-height: 30px; margin-bottom: 10px;\">来个算法题：一个无序数组，其中一个数字出现的次数大于其他数字之和，求这个数字 （主元素）</li><li style=\"line-height: 30px; margin-bottom: 10px;\">答完再来一个：一个数组，有正有负，不改变顺序的情况下，求和最大的最长子序列</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目用到什么数据库？隔离级别？每个隔离级别各做了什么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">数据库的索引？mysql不同引擎索引的区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">垃圾回收算法的过程</li><li style=\"line-height: 30px; margin-bottom: 10px;\">你了解的垃圾收集器？ Cms收集器的过程</li><li style=\"line-height: 30px; margin-bottom: 10px;\">怎样进入老年代？</li><li style=\"line-height: 30px; margin-bottom: 10px;\">平时用到了什么设计模式？</li><li style=\"line-height: 30px; margin-bottom: 10px;\">讲一下你最熟的两个设计模式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">用过什么系统？shell写过脚本吗？</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">小米内推</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（电话）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">看你最近博客写的是redis，介绍redis和mysql的区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Redis的应用场景</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hashmap的原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hashmap中jdk1.8之后做了哪些优化</li><li style=\"line-height: 30px; margin-bottom: 10px;\">垃圾回收的过程</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Jvm的参数设置</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目中的优化</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">金山wps内推</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（电话）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">对Java的面向对象的理解</li><li style=\"line-height: 30px; margin-bottom: 10px;\">对java多线程的理解</li><li style=\"line-height: 30px; margin-bottom: 10px;\">数据库的索引</li><li style=\"line-height: 30px; margin-bottom: 10px;\">数据库的隔离级别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">设计模式的理解</li><li style=\"line-height: 30px; margin-bottom: 10px;\">讲几个设计模式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">对算法有什么了解？答主先回答了动态规划，解释了一下dp的思想</li><li style=\"line-height: 30px; margin-bottom: 10px;\">快排的思想讲一下</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面（电话）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Tcp怎么保证可靠传输（中间穿插了好多小问题）</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Tcp的拥塞控制</li><li style=\"line-height: 30px; margin-bottom: 10px;\">让你设计一个即时聊天的系统</li><li style=\"line-height: 30px; margin-bottom: 10px;\">支付宝转账，是如何实现，几个小时通知转账成功的（面试官想让回答长连接，答主一直没get到点）</li><li style=\"line-height: 30px; margin-bottom: 10px;\">解释一下长连接</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">多益网络</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（视频）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">对面向对象的理解</li><li style=\"line-height: 30px; margin-bottom: 10px;\">介绍多态</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Java新建线程有哪几种方式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">线程池的作用</li><li style=\"line-height: 30px; margin-bottom: 10px;\">看过框架源码么</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">拼多多学霸批</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（现场面）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手撕算法：一棵二叉排序树，给定一个数，找到与给定数差值最小的数</li><li style=\"line-height: 30px; margin-bottom: 10px;\">场景题：设计一个系统，解决抢购时所需要的大量的短链接的功能，如何保证高并发，如何设计短链接</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面（现场面）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">代码量多少</li><li style=\"line-height: 30px; margin-bottom: 10px;\">给了一张纸，各种名词，会的写出来</li><li style=\"line-height: 30px; margin-bottom: 10px;\">然后给它解释那些会的</li><li style=\"line-height: 30px; margin-bottom: 10px;\">设计题：设计一个系统，记录qq用户前一天的登录状态，提供16g内存和2tb的硬盘，要做到查询指定qq号的前一天的登录状态，快速查询O(1)复杂度</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">搜狗校招</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（现场）：</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手撕算法：两个排序的数组A和B分别含有m和n个数，找到两个排序数组的中位数，答主用的二分，时间复杂度为O(log (m+n))。结果面试官不满意，让用归并的思想做，时间复杂度其实更高了</li><li style=\"line-height: 30px; margin-bottom: 10px;\">介绍网络编程</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">涂鸦移动</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">数据库的索引原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">索引使用的注意事项</li><li style=\"line-height: 30px; margin-bottom: 10px;\">数据库的引擎</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Java垃圾回收机制</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Java的finalize，finally，final三个关键字的区别和应用场景</li><li style=\"line-height: 30px; margin-bottom: 10px;\">String类可以被继承么<br>手撕算法：假设你是一个专业的窃贼，准备沿着一条街打劫房屋。每个房子都存放着特定金额的钱。你面临的唯一约束条件是：相邻的房子装着相互联系的防盗系统，且 当相邻的两个房子同一天被打劫时，该系统会自动报警。<br>给定一个非负整数列表，表示每个房子中存放的钱， 算一算，如果今晚去打劫，你最多可以得到多少钱 在不触动报警装置的情况下。</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面（电话）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">对游戏的了解</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">算法题：给一个整数数组，找到两个数使得他们的和等于一个给定的数 target。</li><li style=\"line-height: 30px; margin-bottom: 10px;\">红黑树</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Redis的应用</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">中国电信it研发中心</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目里用的什么服务器</li><li style=\"line-height: 30px; margin-bottom: 10px;\">自己写一个tomcat服务器，你会怎么写</li><li style=\"line-height: 30px; margin-bottom: 10px;\">分布式服务器会出现哪些问题</li><li style=\"line-height: 30px; margin-bottom: 10px;\">怎么解决session一致性缓存的问题</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Redis的优势和特点</li><li style=\"line-height: 30px; margin-bottom: 10px;\">一千万用户并发抢购，怎么设计</li><li style=\"line-height: 30px; margin-bottom: 10px;\">如果成功的用户有10万，redis存不下怎么处理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">你项目中的难点</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">介绍spring中的熟悉的注解</li><li style=\"line-height: 30px; margin-bottom: 10px;\">让你实现autowire注解的功能你会如何实现</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Redis和mysql的区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Redis的持久化有哪些方式，具体原理</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">中兴</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">专业面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">你了解的设计模式，讲两个</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Java collection类，集合，讲两个你了解的，说实现原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Java线程池的作用</li><li style=\"line-height: 30px; margin-bottom: 10px;\">你觉得你在你实验室处于什么水平</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">综合面试（现场）</h2><p style=\"margin-bottom: 25px; word-break: break-word !important;\">说好的综合面试纯聊天呢？<br>1． 自我介绍<br>2． 项目介绍<br>3． 说一下你知道的设计模式<br>4． 画一个策略模式的uml图<br>5． Java多线程的理解<br>6． 内存屏障是什么<br>7． 数据库索引<br>8． 项目中的优化<br>9． 然后开始聊人生<br>10． 你的缺点，你最不喜欢什么样的人，你的家庭等等</p><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">华为</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目架构</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目一个完整的执行流程（由于我是搞java的，而面试官是搞c的，所以全程尬聊）</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目优化</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">怎么管理项目进度</li><li style=\"line-height: 30px; margin-bottom: 10px;\">平常的爱好</li><li style=\"line-height: 30px; margin-bottom: 10px;\">感觉面试官也不是搞java的，所以又是一阵尬聊</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">苏宁内推</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">面过哪些公司了</li><li style=\"line-height: 30px; margin-bottom: 10px;\">有哪些offer了</li><li style=\"line-height: 30px; margin-bottom: 10px;\">聊到多益，于是开始聊最近微博上很火的多益老板</li><li style=\"line-height: 30px; margin-bottom: 10px;\">得出结论，我和面试官都觉得多益老板三观有问题，但做游戏就是要偏执的人</li><li style=\"line-height: 30px; margin-bottom: 10px;\">你博客主要哪方面的</li><li style=\"line-height: 30px; margin-bottom: 10px;\">多线程并发包了解么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">讲一下countDownLatch</li></ol><p style=\"margin-bottom: 25px; word-break: break-word !important;\">苏宁聊了20分钟八卦就面完了，一轮技术面</p><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">美团内推</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（电话）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Redis介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">了解redis源码么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">了解redis集群么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hashmap的原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">hashmap容量为什么是2的幂次</li><li style=\"line-height: 30px; margin-bottom: 10px;\">hashset的源码</li><li style=\"line-height: 30px; margin-bottom: 10px;\">object类你知道的方法</li><li style=\"line-height: 30px; margin-bottom: 10px;\">hashcode和equals</li><li style=\"line-height: 30px; margin-bottom: 10px;\">你重写过hashcode和equals么，要注意什么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">假设现在一个学生类，有学号和姓名，我现在hashcode方法重写的时候，只将学号参与计算，会出现什么情况？</li><li style=\"line-height: 30px; margin-bottom: 10px;\">往set里面put一个学生对象，然后将这个学生对象的学号改了，再put进去，可以放进set么？并讲出为什么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Redis的持久化？有哪些方式，原理是什么？</li><li style=\"line-height: 30px; margin-bottom: 10px;\">讲一下稳定的排序算法和不稳定的排序算法</li><li style=\"line-height: 30px; margin-bottom: 10px;\">讲一下快速排序的思想</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">讲一下数据的acid</li><li style=\"line-height: 30px; margin-bottom: 10px;\">什么是一致性</li><li style=\"line-height: 30px; margin-bottom: 10px;\">什么是隔离性</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Mysql的隔离级别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">每个隔离级别是如何解决</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Mysql要加上nextkey锁，语句该怎么写</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Java的内存模型，垃圾回收</li><li style=\"line-height: 30px; margin-bottom: 10px;\">线程池的参数</li><li style=\"line-height: 30px; margin-bottom: 10px;\">每个参数解释一遍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">然后面试官设置了每个参数，给了是个线程，让描述出完整的线程池执行的流程</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Nio和IO有什么区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Nio和aio的区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Spring的aop怎么实现</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Spring的aop有哪些实现方式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">动态代理的实现方式和区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Linux了解么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">怎么查看系统负载</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Cpu load的参数如果为4，描述一下现在系统处于什么情况</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Linux，查找磁盘上最大的文件的命令</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Linux，如何查看系统日志文件</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手撕算法：leeetcode原题 22，Generate Parentheses，给定 n 对括号，请写一个函数以将其生成新的括号组合，并返回所有组合结果。</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">三面（现场）</h2><p style=\"margin-bottom: 25px; word-break: break-word !important;\">三面没怎么问技术，问了很多技术管理方面的问题</p><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">怎么管理项目成员</li><li style=\"line-height: 30px; margin-bottom: 10px;\">当意见不一致时，如何沟通并说服开发成员，并举个例子</li><li style=\"line-height: 30px; margin-bottom: 10px;\">怎么保证项目的进度</li><li style=\"line-height: 30px; margin-bottom: 10px;\">数据库的索引原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">非聚簇索引和聚簇索引</li><li style=\"line-height: 30px; margin-bottom: 10px;\">索引的使用注意事项</li><li style=\"line-height: 30px; margin-bottom: 10px;\">联合索引</li><li style=\"line-height: 30px; margin-bottom: 10px;\">从底层解释最左匹配原则</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Mysql对联合索引有优化么？会自动调整顺序么？哪个版本开始优化？</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Redis的应用</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Redis的持久化的方式和原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">技术选型，一个新技术和一个稳定的旧技术，你会怎么选择，选择的考虑有哪些</li><li style=\"line-height: 30px; margin-bottom: 10px;\">说你印象最深的美团点评技术团队的三篇博客</li><li style=\"line-height: 30px; margin-bottom: 10px;\">最近在学什么新技术</li><li style=\"line-height: 30px; margin-bottom: 10px;\">你是怎么去接触一门新技术的</li><li style=\"line-height: 30px; margin-bottom: 10px;\">会看哪些书</li><li style=\"line-height: 30px; margin-bottom: 10px;\">怎么选择要看的书</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">百度</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Java中的多态</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Object类下的方法</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Finalize的作用和使用场景</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hashcode和equals</li><li style=\"line-height: 30px; margin-bottom: 10px;\">为什么要同时重写hashcode和equals</li><li style=\"line-height: 30px; margin-bottom: 10px;\">不同时重写会出现哪些问题</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hashmap的原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hashmap如何变线程安全，每种方式的优缺点</li><li style=\"line-height: 30px; margin-bottom: 10px;\">垃圾回收机制</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Jvm的参数你知道的说一下</li><li style=\"line-height: 30px; margin-bottom: 10px;\">设计模式了解的说一下啊</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手撕一个单例模式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">快速排序的思想讲一下</li><li style=\"line-height: 30px; margin-bottom: 10px;\">给个数组，模拟快排的过程</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手写快排</li><li style=\"line-height: 30px; margin-bottom: 10px;\">设计题，一个图书馆管理系统，数据库怎么设计，需求自己定</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Redis的特点</li><li style=\"line-height: 30px; margin-bottom: 10px;\">分布式事务了解么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">反爬虫的机制，有哪些方式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手撕算法：反转单链表</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手撕算法：实现类似微博子结构的数据结构，输入一系列父子关系，输出一个类似微博评论的父子结构图</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手写java多线程</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手写java的soeket编程，服务端和客户端</li><li style=\"line-height: 30px; margin-bottom: 10px;\">进程间的通信方式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手撕算法： 爬楼梯，写出状态转移方程</li><li style=\"line-height: 30px; margin-bottom: 10px;\">智力题：时针分针什么时候重合</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">三面（现场）</h2><p style=\"margin-bottom: 25px; word-break: break-word !important;\">由于三面面试官不懂java，我不熟c加加，所以全程尬聊</p><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手撕算法：给定一个数字三角形，找到从顶部到底部的最小路径和。每一步可以移动到下面一行的相邻数字上。</li><li style=\"line-height: 30px; margin-bottom: 10px;\"></li><li style=\"line-height: 30px; margin-bottom: 10px;\">然后继续在这个问题上扩展</li><li style=\"line-height: 30px; margin-bottom: 10px;\">求出最短那条的路径</li><li style=\"line-height: 30px; margin-bottom: 10px;\">递归求出所有的路径</li><li style=\"line-height: 30px; margin-bottom: 10px;\">设计模式讲一下熟悉的</li><li style=\"line-height: 30px; margin-bottom: 10px;\">会不会滥用设计模式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">多线程条件变量为什么要在while体里</li><li style=\"line-height: 30px; margin-bottom: 10px;\">你遇到什么挫折</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">腾讯</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hibernate的作用，你的理解</li><li style=\"line-height: 30px; margin-bottom: 10px;\">多线程的理解，如何保证线程安全</li><li style=\"line-height: 30px; margin-bottom: 10px;\">mysql数据库的引擎和区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">场景题：千万用户抢购，如何处理高并发，并且有一个链接，指向前一天抢购成功的用户，如何设计这个系统和数据库</li><li style=\"line-height: 30px; margin-bottom: 10px;\">如果后台处理抢购请求的服务器，每次最多承受200的负载，系统该怎么设计</li><li style=\"line-height: 30px; margin-bottom: 10px;\">手撕算法：最小公倍数和最大公约数</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目里一个完整请求的流程</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目的优化</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hibernate和mybatis的区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">为什么用ssh框架</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Mysql的容灾备份</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Redis和memcache 的区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">为什么选择redis</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Java的full gc</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Full gc会导致什么问题</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">招商银行信用卡</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">分布式事务</li><li style=\"line-height: 30px; margin-bottom: 10px;\">设计模式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">访问者模式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">装饰者模式</li><li style=\"line-height: 30px; margin-bottom: 10px;\">有哪些offer</li><li style=\"line-height: 30px; margin-bottom: 10px;\">为什么还来我们这</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">招银网络科技</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">写一个两个有序链表合并成一个有序链表</li><li style=\"line-height: 30px; margin-bottom: 10px;\">死锁是什么呢</li><li style=\"line-height: 30px; margin-bottom: 10px;\">怎么解决死锁</li><li style=\"line-height: 30px; margin-bottom: 10px;\">http请求流程</li><li style=\"line-height: 30px; margin-bottom: 10px;\">为什么负载均衡</li><li style=\"line-height: 30px; margin-bottom: 10px;\">怎么实现负载均衡</li><li style=\"line-height: 30px; margin-bottom: 10px;\">数据库挂了怎么办？除了热备份还有什么方法</li><li style=\"line-height: 30px; margin-bottom: 10px;\">讲讲你对spring的理解，不要把ioc和aop背给我听</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">算法：找出两个数组相等的数，不能用其他数据结构</li><li style=\"line-height: 30px; margin-bottom: 10px;\">算法：给定一个数字，一个数组，找出数组中相加等于这两个数的和，不能用数据结构</li><li style=\"line-height: 30px; margin-bottom: 10px;\">算法：如何判断一个树是不是另一颗树的子树</li><li style=\"line-height: 30px; margin-bottom: 10px;\">如何解决并发访问的错误</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">网易</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面（现场）</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">I++操作怎么保证线程安全</li><li style=\"line-height: 30px; margin-bottom: 10px;\">场景题：设计一个下单系统，下单成功后可以给用户发优惠券</li><li style=\"line-height: 30px; margin-bottom: 10px;\">接上面场景题：服务器挂了，优惠券还没发怎么办</li><li style=\"line-height: 30px; margin-bottom: 10px;\">数据库挂了怎么怎么办</li><li style=\"line-height: 30px; margin-bottom: 10px;\">怎么保证一致性</li><li style=\"line-height: 30px; margin-bottom: 10px;\">分布式事务知道么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">介绍分布式事务</li><li style=\"line-height: 30px; margin-bottom: 10px;\">你的职业规划</li></ol><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">二面</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Nio的原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Channel和buffer</li><li style=\"line-height: 30px; margin-bottom: 10px;\">directBuffer和buffer的区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">nio和aio的区别</li><li style=\"line-height: 30px; margin-bottom: 10px;\">锁的实现原理</li><li style=\"line-height: 30px; margin-bottom: 10px;\">怎么解决缓存和主存的一致性问题</li><li style=\"line-height: 30px; margin-bottom: 10px;\">缓存还没更新到主存，服务器挂了怎么办</li><li style=\"line-height: 30px; margin-bottom: 10px;\">数据库挂了怎么办</li></ol><h1 style=\"font-size: 26px; margin-top: 0px; margin-bottom: 15px; font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); text-rendering: optimizeLegibility;\">Vivo</h1><h2 style=\"font-family: inherit; font-weight: 700; line-height: 1.7; color: rgb(47, 47, 47); margin: 0px 0px 15px; font-size: 24px; text-rendering: optimizeLegibility;\">一面</h2><ol style=\"margin-bottom: 20px; padding: 0px; margin-left: 22px; word-break: break-word !important;\"><li style=\"line-height: 30px; margin-bottom: 10px;\">自我介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">项目介绍</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Hibernate的batch有数量限制么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Jquery用过么</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Extjs的优缺点</li><li style=\"line-height: 30px; margin-bottom: 10px;\">有没有扩展过extjs</li><li style=\"line-height: 30px; margin-bottom: 10px;\">读写锁</li><li style=\"line-height: 30px; margin-bottom: 10px;\">什么时候用读锁</li><li style=\"line-height: 30px; margin-bottom: 10px;\">什么时候用写锁</li><li style=\"line-height: 30px; margin-bottom: 10px;\">Cas的原理，使用场景</li><li style=\"line-height: 30px; margin-bottom: 10px;\">数据库的瓶颈</li></ol><div><br></div><div><br></div><div>转自<a href=\"http://www.jianshu.com//p/72712546648b\" target=\"_blank\">http://www.jianshu.com//p/72712546648b</a></div></div>', 'article', null, '', null, null, '1', null, '0', '1', 'Bootdo', '2017-10-13 13:45:20', '2017-10-13 13:45:20');
INSERT INTO `blog_content` VALUES ('121', 'Spring Cloud下微服务权限方案', null, null, null, '<p><br></p><div class=\"Layout-navbarHolder\" style=\"box-sizing: inherit; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; flex-direction: column; -webkit-box-align: stretch; align-items: stretch; flex-shrink: 0; height: 59px; color: rgb(51, 51, 51); font-family: -apple-system, &quot;Helvetica Neue&quot;, Arial, &quot;PingFang SC&quot;, &quot;Hiragino Sans GB&quot;, &quot;Microsoft YaHei&quot;, &quot;WenQuanYi Micro Hei&quot;, sans-serif; font-size: medium;\"><header class=\"Navbar ScrollBackFixed\" style=\"box-sizing: inherit; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; flex-direction: row; -webkit-box-align: center; align-items: center; flex-shrink: 0; contain: layout; -webkit-box-pack: justify; justify-content: space-between; height: 59px; width: 1519.2px; border-bottom: 1px solid rgba(0, 0, 0, 0.08); color: rgb(128, 128, 128); background: rgba(255, 255, 255, 0.97); z-index: 2; position: fixed; border-top-color: rgba(0, 0, 0, 0.08); border-right-color: rgba(0, 0, 0, 0.08); border-left-color: rgba(0, 0, 0, 0.08); transform: translateY(-100%); will-change: transform;\"><div class=\"Navbar-functionality\" style=\"box-sizing: inherit; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; flex-direction: row; -webkit-box-align: center; align-items: center; flex-shrink: 0; position: absolute; right: 0px; top: 0px; height: 58px; align-self: stretch;\"><a class=\"Navbar-write\" style=\"box-sizing: inherit; color: inherit; display: flex; -webkit-box-align: center; align-items: center; padding: 0px 10px; white-space: nowrap; transition: color 0.2s;\"><span class=\"icon icon-ic_nav_new\" style=\"box-sizing: inherit; font-size: 24px; speak: none; font-feature-settings: normal; line-height: 1; -webkit-font-smoothing: antialiased; margin-right: 3px; font-family: icomoon !important;\"></span>写文章</a><button class=\"Button Navbar-loginButon Button--blue\" type=\"button\" style=\"box-sizing: inherit; padding: 0px 16px; color: rgb(0, 128, 255); font-size: 14px; line-height: 30px; background-image: none; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; border-width: 1px; border-style: solid; border-color: rgb(0, 128, 255); -webkit-appearance: none; border-radius: 4px; height: 32px; margin-right: 16px; margin-left: 6px; width: 72px;\">登录</button></div></header></div><div style=\"box-sizing: inherit; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; flex-direction: column; -webkit-box-align: stretch; align-items: stretch; flex-shrink: 0; color: rgb(51, 51, 51); font-family: -apple-system, &quot;Helvetica Neue&quot;, Arial, &quot;PingFang SC&quot;, &quot;Hiragino Sans GB&quot;, &quot;Microsoft YaHei&quot;, &quot;WenQuanYi Micro Hei&quot;, sans-serif; font-size: medium;\"></div><div class=\"Layout-main av-card av-paddingBottom av-bodyFont Layout-titleImage--normal\" style=\"box-sizing: inherit; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; flex-direction: column; -webkit-box-align: stretch; align-items: stretch; flex-shrink: 0; margin: 22px auto 0px; padding: 0px; width: 660px; z-index: 1; color: rgb(51, 51, 51); font-family: -apple-system, &quot;Helvetica Neue&quot;, Arial, &quot;PingFang SC&quot;, &quot;Hiragino Sans GB&quot;, &quot;Microsoft YaHei&quot;, &quot;WenQuanYi Micro Hei&quot;, sans-serif; font-size: medium;\"><div class=\"PostIndex-header av-paddingTop av-card\" data-zop=\"{&quot;authorName&quot;:&quot;老A&quot;,&quot;itemId&quot;:&quot;29345083&quot;,&quot;title&quot;:&quot;Spring Cloud下微服务权限方案&quot;,&quot;type&quot;:&quot;article&quot;}\" data-za-module=\"PostItem\" data-za-module-info=\"{&quot;card&quot;:{&quot;content&quot;:{&quot;type&quot;:&quot;Post&quot;,&quot;token&quot;:&quot;29345083&quot;}}}\" style=\"box-sizing: inherit; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; flex-direction: column; -webkit-box-align: stretch; align-items: stretch; flex-shrink: 0; position: relative;\"><div class=\"TitleImage\" style=\"box-sizing: inherit; -webkit-box-orient: vertical; -webkit-box-direction: normal; flex-direction: column; -webkit-box-align: stretch; align-items: stretch; flex-shrink: 0; margin-bottom: 22px;\"><img alt=\"Spring Cloud下微服务权限方案\" src=\"https://pic4.zhimg.com/v2-32e374b99a4332ca8bd52fca9d090617_r.png\" class=\"TitleImage-imagePure TitleImage-imagePure--fixed\" height=\"396px\" style=\"box-sizing: inherit; overflow: hidden; width: 660px; display: block;\"></div><h1 class=\"PostIndex-title av-paddingSide av-titleFont\" style=\"box-sizing: inherit; margin-top: 0px; margin-bottom: 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; font-size: 32px; line-height: 1.3;\">Spring Cloud下微服务权限方案</h1><div class=\"PostIndex-author\" style=\"box-sizing: inherit; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; flex-direction: row; -webkit-box-align: center; align-items: center; flex-shrink: 0; position: relative; font-size: 14px; color: rgb(128, 128, 128); margin-top: 22px;\"><a href=\"https://www.zhihu.com/people/lao-a-68-38\" target=\"_blank\" style=\"box-sizing: inherit; color: inherit;\"><img class=\"Avatar-hemingway PostIndex-authorAvatar Avatar--xs\" alt=\"老A\" src=\"https://pic1.zhimg.com/v2-3b6c82a0652b73ee56207a2f45955ca8_xs.jpg\" srcset=\"https://pic1.zhimg.com/v2-3b6c82a0652b73ee56207a2f45955ca8_l.jpg 2x\" style=\"box-sizing: inherit; overflow: hidden; width: 36px; height: 36px; border-radius: 50%; margin-right: 12px;\"></a><a href=\"https://www.zhihu.com/people/lao-a-68-38\" target=\"_blank\" class=\"PostIndex-authorName\" style=\"box-sizing: inherit; color: rgb(128, 128, 128); min-width: 0px; text-overflow: ellipsis; white-space: nowrap; overflow: hidden;\">老A</a><span class=\"Bull\" style=\"box-sizing: inherit; margin: 0px 6px;\"></span><div class=\"HoverTitle\" data-hover-title=\"2017 年 9月 14 日星期四晚上 7 点 12 分\" style=\"box-sizing: inherit; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; flex-direction: column; -webkit-box-align: stretch; align-items: stretch; flex-shrink: 0; position: relative;\"><time datetime=\"Thu Sep 14 2017 19:12:26 GMT+0800 (中国标准时间)\" style=\"box-sizing: inherit;\">1 个月前</time></div></div></div><div class=\"RichText PostIndex-content av-paddingSide av-card\" style=\"box-sizing: inherit; -webkit-box-orient: vertical; -webkit-box-direction: normal; flex-direction: column; -webkit-box-align: stretch; align-items: stretch; flex-shrink: 0; word-break: break-word; margin: 30px 0px; line-height: 1.7;\"><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">背景</h2><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">从传统的单体应用转型Spring Cloud的朋友都在问我，Spring Cloud下的微服务权限怎么管？怎么设计比较合理？从大层面讲叫服务权限，往小处拆分，分别为三块：用户认证、用户权限、服务校验。</p><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">用户认证</h2><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">传统的单体应用可能习惯了session的存在，而到了Spring cloud的微服务化后，session虽然可以采取分布式会话来解决，但终究不是上上策。开始有人推行Spring Cloud Security结合很好的OAuth2，后面为了优化OAuth 2中Access Token的存储问题，提高后端服务的可用性和扩展性，有了更好Token验证方式JWT（JSON Web Token）。这里要强调一点的是，OAuth2和JWT这两个根本没有可比性，是两个完全不同的东西。 OAuth2是一种授权框架，而JWT是一种认证协议</p><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">OAuth2认证框架</h2><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">OAuth2中包含四个角色：</h2><ul style=\"box-sizing: inherit; margin: 20px 0px; padding: 0px 0px 0px 40px;\"><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">资源拥有者(Resource Owner)</li><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">资源服务器(Resource Server)</li><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">授权服务器(Authorization Server)</li><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">客户端(Client)</li></ul><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">OAuth2包含4种授权模式</h2><ul style=\"box-sizing: inherit; margin: 20px 0px; padding: 0px 0px 0px 40px;\"><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">授权码（认证码）模式 （Authorization code)</li><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">简化（隐形）模式 (Impilict</li><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">用户名密码模式 (Resource Owner Password Credential)</li><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">客户端模式 (Client Credential)</li></ul><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">其中，OAuth2的运行流程如下图，摘自RFC 6749：</p><div class=\"highlight\" style=\"box-sizing: inherit; -webkit-box-orient: vertical; -webkit-box-direction: normal; flex-direction: column; -webkit-box-align: stretch; align-items: stretch; flex-shrink: 0;\"><pre style=\"box-sizing: inherit; margin-top: 1em; margin-bottom: 1em; padding: 10px; font-family: Menlo, Monaco, Consolas, &quot;Andale Mono&quot;, &quot;lucida console&quot;, &quot;Courier New&quot;, monospace; font-size: 14px; word-wrap: normal; background: rgb(235, 238, 245);\"><code class=\"language-text\" style=\"box-sizing: inherit; font-family: Menlo, Monaco, Consolas, &quot;Andale Mono&quot;, &quot;lucida console&quot;, &quot;Courier New&quot;, monospace;\"><span style=\"box-sizing: inherit;\"></span>+--------+                               +---------------+\r\n|        |--(A)- Authorization Request -&gt;|   Resource    |\r\n|        |                               |     Owner     |\r\n|        |&lt;-(B)-- Authorization Grant ---|               |\r\n|        |                               +---------------+\r\n|        |\r\n|        |                               +---------------+\r\n|        |--(C)-- Authorization Grant --&gt;| Authorization |\r\n| Client |                               |     Server    |\r\n|        |&lt;-(D)----- Access Token -------|               |\r\n|        |                               +---------------+\r\n|        |\r\n|        |                               +---------------+\r\n|        |--(E)----- Access Token ------&gt;|    Resource   |\r\n|        |                               |     Server    |\r\n|        |&lt;-(F)--- Protected Resource ---|               |\r\n+--------+                               +---------------+\r\n</code></pre></div><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">我们在Spring Cloud OAuth2中，所有访问微服务资源的请求都在Http Header中携带Token，被访问的服务接下来再去请求授权服务器验证Token的有效性，目前这种方式，我们需要两次或者更多次的请求，所有的Token有效性校验都落在的授权服务器上，对于我们系统的水平扩展成为一个非常大的瓶颈。</p><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">JWT认证协议</h2><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">授权服务器将用户信息和授权范围序列化后放入一个JSON字符串，然后使用Base64进行编码，最终在授权服务器用私钥对这个字符串进行签名，得到一个JSON Web Token。</p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">假设其他所有的资源服务器都将持有一个RSA公钥，当资源服务器接收到这个在Http Header中存有Token的请求，资源服务器就可以拿到这个Token，并验证它是否使用正确的私钥签名（是否经过授权服务器签名，也就是验签）。验签通过，反序列化后就拿到Toekn中包含的有效验证信息。</p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">其中，主体运作流程图如下：</p><div class=\"highlight\" style=\"box-sizing: inherit; -webkit-box-orient: vertical; -webkit-box-direction: normal; flex-direction: column; -webkit-box-align: stretch; align-items: stretch; flex-shrink: 0;\"><pre style=\"box-sizing: inherit; margin-top: 1em; margin-bottom: 1em; padding: 10px; font-family: Menlo, Monaco, Consolas, &quot;Andale Mono&quot;, &quot;lucida console&quot;, &quot;Courier New&quot;, monospace; font-size: 14px; word-wrap: normal; background: rgb(235, 238, 245);\"><code class=\"language-text\" style=\"box-sizing: inherit; font-family: Menlo, Monaco, Consolas, &quot;Andale Mono&quot;, &quot;lucida console&quot;, &quot;Courier New&quot;, monospace;\"><span style=\"box-sizing: inherit;\"></span>+-----------+                                     +-------------+\r\n|           |       1-Request Authorization       |             |\r\n|           |------------------------------------&gt;|             |\r\n|           |     grant_type&amp;username&amp;password    |             |--+\r\n|           |                                     |Authorization|  | 2-Gen\r\n|           |                                     |Service      |  |   JWT\r\n|           |       3-Response Authorization      |             |&lt;-+\r\n|           |&lt;------------------------------------| Private Key |\r\n|           |    access_token / refresh_token     |             |\r\n|           |    token_type / expire_in           |             |\r\n|  Client   |                                     +-------------+\r\n|           |                                 \r\n|           |                                     +-------------+\r\n|           |       4-Request Resource            |             |\r\n|           |-----------------------------------&gt; |             |\r\n|           | Authorization: bearer Access Token  |             |--+\r\n|           |                                     | Resource    |  | 5-Verify\r\n|           |                                     | Service     |  |  Token\r\n|           |       6-Response Resource           |             |&lt;-+\r\n|           |&lt;----------------------------------- | Public Key  |\r\n+-----------+                                     +-------------+\r\n</code></pre></div><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">通过上述的方式，我们可以很好地完成服务化后的用户认证。</p><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">用户权限</h2><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">传统的单体应用的权限拦截，大家都喜欢shiro，而且用的颇为顺手。可是一旦拆分后，这权限开始分散在各个API了，shiro还好使吗？笔者在项目中，并没有用shiro。前后端分离后，交互都是token，后端的服务无状态化，前端按钮资源化，权限放哪儿管好使？</p><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">抽象与设计</h2><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">在介绍灵活的核心设计前，先给大家普及一个入门的概念：RBAC（Role-Based Access Control，基于角色的访问控制），就是用户通过角色与权限进行关联。简单地说，一个用户拥有若干角色，每一个角色拥有若干权限。</p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">RBAC其实是一种分析模型，主要分为：基本模型RBAC0（Core RBAC）、角色分层模型RBAC1（Hierarchal RBAC）、角色限制模型RBAC2（Constraint RBAC）和统一模型RBAC3（Combines RBAC）。</p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">更多详情大家可以了解：<a href=\"http://link.zhihu.com/?target=http%3A//blog.csdn.net/zwk626542417/article/details/46726491\" class=\" wrap external\" target=\"_blank\" rel=\"nofollow noreferrer\" style=\"box-sizing: inherit; color: rgb(34, 85, 153); border-bottom: 1px solid rgba(64, 64, 64, 0.72); word-break: break-all;\">RBAC权限模型<span class=\"icon-external\" style=\"box-sizing: inherit; font-size: 24px; speak: none; font-feature-settings: normal; line-height: 1; -webkit-font-smoothing: antialiased; font-family: icomoon !important;\"></span></a></p><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">核心UML</h2><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\"><br style=\"box-sizing: inherit;\"></p><img src=\"https://pic2.zhimg.com/v2-3e3eed438a7df522714407c5436c9bc9_b.png\" data-rawwidth=\"1168\" data-rawheight=\"532\" class=\"origin_image zh-lightbox-thumb lazy\" width=\"1168\" data-original=\"https://pic2.zhimg.com/v2-3e3eed438a7df522714407c5436c9bc9_r.png\" data-actualsrc=\"https://pic2.zhimg.com/v2-3e3eed438a7df522714407c5436c9bc9_b.png\" style=\"box-sizing: inherit; overflow: hidden; display: block; max-width: 100%; margin: 24px auto; cursor: -webkit-zoom-in;\"><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">这是笔者通过多种业务场景后抽象的RBAC关系图</p><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">类说明</h2><ul style=\"box-sizing: inherit; margin: 20px 0px; padding: 0px 0px 0px 40px;\"><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">Group</li></ul><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">群或组，拥有一定数量权限的集合，亦可以是权限的载体。</p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">子类：User（用户）、Role（角色）、Position（岗位）、Unit（部门），通过用户的特定构成，形成不同业务场景的群或组，而通过对群或组的父类授权，完成了用户的权限获取。</p><ul style=\"box-sizing: inherit; margin: 20px 0px; padding: 0px 0px 0px 40px;\"><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">Permission</li></ul><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">权限，拥有一定数量资源的集成，亦可以是资源的载体。</p><ul style=\"box-sizing: inherit; margin: 20px 0px; padding: 0px 0px 0px 40px;\"><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">Resources</li></ul><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">权限下有资源，资源的来源有：Menu（菜单）、Button（动作权限）、页面元素（按钮、tab等）、数据权限等</p><ul style=\"box-sizing: inherit; margin: 20px 0px; padding: 0px 0px 0px 40px;\"><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">Program</li></ul><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">程序，相关权限控制的呈现载体，可以在多个菜单中挂载。</p><ul style=\"box-sizing: inherit; margin: 20px 0px; padding: 0px 0px 0px 40px;\"><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">常见web程序基本构成</li></ul><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\"><br style=\"box-sizing: inherit;\"></p><img src=\"https://pic1.zhimg.com/v2-9f156709621fdd7685db9781829e2948_b.png\" data-rawwidth=\"873\" data-rawheight=\"492\" class=\"origin_image zh-lightbox-thumb lazy\" width=\"873\" data-original=\"https://pic1.zhimg.com/v2-9f156709621fdd7685db9781829e2948_r.png\" data-actualsrc=\"https://pic1.zhimg.com/v2-9f156709621fdd7685db9781829e2948_b.png\" style=\"box-sizing: inherit; overflow: hidden; display: block; max-width: 100%; margin: 24px auto; cursor: -webkit-zoom-in;\"><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\"><br style=\"box-sizing: inherit;\"></p><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">模型与微服务的关系</h2><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">如果把Spring Cloud服务化后的所有api接口都定义为上文的Resources，那么我们可以看到这么一个情况。</p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">比如一个用户的增删改查，我们的页面会这么做</p><img src=\"https://pic1.zhimg.com/v2-ac1fa4fc0005af11c0a7aa59fe62cbbc_b.png\" data-rawwidth=\"2880\" data-rawheight=\"1460\" class=\"origin_image zh-lightbox-thumb lazy\" width=\"2880\" data-original=\"https://pic1.zhimg.com/v2-ac1fa4fc0005af11c0a7aa59fe62cbbc_r.png\" data-actualsrc=\"https://pic1.zhimg.com/v2-ac1fa4fc0005af11c0a7aa59fe62cbbc_b.png\" style=\"box-sizing: inherit; overflow: hidden; display: block; max-width: 100%; margin: 24px auto; cursor: -webkit-zoom-in;\"><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\"><br style=\"box-sizing: inherit;\"></p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">页面元素资源编码资源URI资源请求方式查询user_btn_get/api/user/{id}GET增加user_btn_add/api/userPOST编辑user_btn_edit/api/user/{id}PUT删除user_btn_del/api/user/{id}DELETE</p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">在抽象成上述的映射关系后，我们的前后端的资源有了参照，我们对于用户组的权限授权就容易了。比如我授予一个用户增加、删除权限。在前端我们只需要检验该资源编码的有无就可以控制按钮的显示和隐藏，而在后端我们只需要统一拦截判断该用户是否具有URI和对应请求方式即可。</p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">至于权限的统一拦截是放置在Zuul这个网关上，还是落在具体的后端服务的拦截器上（Filter、Inteceptor），都可以轻而易举地实现。不在局限于代码的侵入性。放置Zuul流程图如下：</p><img src=\"https://pic3.zhimg.com/v2-efbe4a2af48e48c86867a49f04759b7a_b.png\" data-rawwidth=\"1426\" data-rawheight=\"710\" class=\"origin_image zh-lightbox-thumb lazy\" width=\"1426\" data-original=\"https://pic3.zhimg.com/v2-efbe4a2af48e48c86867a49f04759b7a_r.png\" data-actualsrc=\"https://pic3.zhimg.com/v2-efbe4a2af48e48c86867a49f04759b7a_b.png\" style=\"box-sizing: inherit; overflow: hidden; display: block; max-width: 100%; margin: 24px auto; cursor: -webkit-zoom-in;\"><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\"><br style=\"box-sizing: inherit;\"></p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">要是权限的统一拦截放置在Zuul上，会有一个问题，那就是后端服务安不安全，服务只需要通过注册中心，即可对其他服务进行调用。这里就涉及到后面的第三个模块，服务之间的鉴权。</p><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">服务之间的鉴权</h2><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">因为我们都知道服务之间开源通过注册中心寻到客户端后，直接远程过程调用的。对于生产上的各个服务，一个个敏感性的接口，我们更是需要加以保护。主题的流程如下图：</p><img src=\"https://pic4.zhimg.com/v2-2c574cb730d4e02834e238d0f7fc40eb_b.png\" data-rawwidth=\"1700\" data-rawheight=\"926\" class=\"origin_image zh-lightbox-thumb lazy\" width=\"1700\" data-original=\"https://pic4.zhimg.com/v2-2c574cb730d4e02834e238d0f7fc40eb_r.png\" data-actualsrc=\"https://pic4.zhimg.com/v2-2c574cb730d4e02834e238d0f7fc40eb_b.png\" style=\"box-sizing: inherit; overflow: hidden; display: block; max-width: 100%; margin: 24px auto; cursor: -webkit-zoom-in;\"><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\"><br style=\"box-sizing: inherit;\"></p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">笔者的实现方式是基于Spring Cloud的FeignClient Inteceprot（自动申请服务token、传递当前上下文）和Mvc Inteceptor（服务token校验、更新当前上下文）来实现，从而对服务的安全性做进一步保护。</p><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">结合Spring Cloud的特性后，整体流程图如下：</p><img src=\"https://pic1.zhimg.com/v2-467d442498d0ed41372a7567fc36a714_b.png\" data-rawwidth=\"2182\" data-rawheight=\"1638\" class=\"origin_image zh-lightbox-thumb lazy\" width=\"2182\" data-original=\"https://pic1.zhimg.com/v2-467d442498d0ed41372a7567fc36a714_r.png\" data-actualsrc=\"https://pic1.zhimg.com/v2-467d442498d0ed41372a7567fc36a714_b.png\" style=\"box-sizing: inherit; overflow: hidden; display: block; max-width: 100%; margin: 24px auto; cursor: -webkit-zoom-in;\"><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\"><br style=\"box-sizing: inherit;\"></p><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">优化点</h2><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">虽然通过上述的用户合法性检验、用户权限拦截以及服务之间的鉴权，保证了Api接口的安全性，但是其间的Http访问频率是比较高的，请求数量上来的时候，慢的问题是就会特别明显。可以考虑一定的优化策略，比如用户权限缓存、服务授权信息的派发与混存、定时刷新服务鉴权Token等。</p><h2 style=\"box-sizing: inherit; margin: 20px 0px; font-style: inherit; font-variant: inherit; font-weight: 700; font-stretch: inherit; line-height: inherit;\">结语</h2><p style=\"box-sizing: inherit; margin-top: 20px; margin-bottom: 20px;\">上述是笔者在项目里的大体思路，有兴趣的朋友可以借鉴我的开源项目，欢迎star：</p><ul style=\"box-sizing: inherit; margin: 20px 0px; padding: 0px 0px 0px 40px;\"><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">gitchina：<a href=\"http://link.zhihu.com/?target=http%3A//git.oschina.net/geek_qi/ace-security%25EF%25BC%2588Jwt%25E3%2580%2581%25E7%2594%25A8%25E6%2588%25B7%25E6%259D%2583%25E9%2599%2590%25EF%25BC%2589\" class=\" wrap external\" target=\"_blank\" rel=\"nofollow noreferrer\" style=\"box-sizing: inherit; color: rgb(34, 85, 153); border-bottom: 1px solid rgba(64, 64, 64, 0.72); word-break: break-all;\">http://git.oschina.net/geek_qi/ace-security（Jwt、用户权限）<span class=\"icon-external\" style=\"box-sizing: inherit; font-size: 24px; speak: none; font-feature-settings: normal; line-height: 1; -webkit-font-smoothing: antialiased; font-family: icomoon !important;\"></span></a></li><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">github：<a href=\"http://link.zhihu.com/?target=https%3A//github.com/wxiaoqi/ace-security\" class=\" external\" target=\"_blank\" rel=\"nofollow noreferrer\" style=\"box-sizing: inherit; color: rgb(34, 85, 153); border-bottom: 1px solid rgba(64, 64, 64, 0.72); word-break: break-all;\"><span class=\"invisible\" style=\"box-sizing: inherit; font-stretch: normal; font-size: 0px; line-height: 0; font-family: a; color: transparent; text-shadow: none; background-color: transparent;\">https://</span><span class=\"visible\" style=\"box-sizing: inherit;\">github.com/wxiaoqi/ace-</span><span class=\"invisible\" style=\"box-sizing: inherit; font-stretch: normal; font-size: 0px; line-height: 0; font-family: a; color: transparent; text-shadow: none; background-color: transparent;\">security</span><span class=\"ellipsis\" style=\"box-sizing: inherit;\"></span><span class=\"icon-external\" style=\"box-sizing: inherit; font-size: 24px; speak: none; font-feature-settings: normal; line-height: 1; -webkit-font-smoothing: antialiased; font-family: icomoon !important;\"></span></a></li><li style=\"box-sizing: inherit; list-style-type: initial; margin-top: 10px; list-style-position: outside;\">gitchina：<a href=\"http://link.zhihu.com/?target=http%3A//git.oschina.net/geek_qi/ace-gate%25EF%25BC%2588%25E6%259C%258D%25E5%258A%25A1%25E9%2589%25B4%25E6%259D%2583%25EF%25BC%2589\" class=\" wrap external\" target=\"_blank\" rel=\"nofollow noreferrer\" style=\"box-sizing: inherit; color: rgb(34, 85, 153); border-bottom: 1px solid rgba(64, 64, 64, 0.72); word-break: break-all;\">http://git.oschina.net/geek_qi/ace-gate（服务鉴权）</a></li></ul></div></div>', 'article', null, '', null, null, '1', null, '0', '1', 'bootdo', '2017-10-25 12:28:19', '2017-10-25 12:28:19'), ('122', '我要发飙了', null, null, null, '<p>这都是什么玩意？？</p>', 'article', null, '11', null, null, '1', null, '1', '1', 'Aron', '2018-01-02 23:51:29', '2018-01-02 23:51:29'), ('128', '1', null, null, null, '<p>3</p>', 'article', null, '4', null, '0', '1', '0', '0', '1', '2', '2018-01-02 23:53:16', '2018-01-02 23:53:16'), ('129', '1', null, null, null, '<p>3</p>', 'article', null, '4', null, '0', '1', '0', '0', '1', '2', '2018-01-02 23:54:49', '2018-01-02 23:54:49'), ('130', '1', null, null, null, '<p>3</p>', 'article', null, '4', null, '0', '1', '0', '0', '1', '2', '2018-01-03 00:01:06', '2018-01-03 00:01:06'), ('131', '1', null, null, null, '<p>3</p>', 'article', null, '4', null, '0', '1', '0', '0', '1', '2', '2018-01-03 00:01:20', '2018-01-03 00:01:20'), ('132', null, null, null, null, '<p><br></p>', 'article', null, null, null, '0', '1', '0', '0', '0', null, '2018-01-03 00:11:03', '2018-01-03 00:11:03');
COMMIT;

-- ----------------------------
--  Table structure for `oa_notify`
-- ----------------------------
DROP TABLE IF EXISTS `oa_notify`;
CREATE TABLE `oa_notify` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '编号',
  `type` char(1) COLLATE utf8_bin DEFAULT NULL COMMENT '类型',
  `title` varchar(200) COLLATE utf8_bin DEFAULT NULL COMMENT '标题',
  `content` varchar(2000) COLLATE utf8_bin DEFAULT NULL COMMENT '内容',
  `files` varchar(2000) COLLATE utf8_bin DEFAULT NULL COMMENT '附件',
  `status` char(1) COLLATE utf8_bin DEFAULT NULL COMMENT '状态',
  `create_by` bigint(20) DEFAULT NULL COMMENT '创建者',
  `create_date` datetime DEFAULT NULL COMMENT '创建时间',
  `update_by` varchar(64) COLLATE utf8_bin DEFAULT NULL COMMENT '更新者',
  `update_date` datetime DEFAULT NULL COMMENT '更新时间',
  `remarks` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '备注信息',
  `del_flag` char(1) COLLATE utf8_bin DEFAULT '0' COMMENT '删除标记',
  PRIMARY KEY (`id`),
  KEY `oa_notify_del_flag` (`del_flag`)
) ENGINE=InnoDB AUTO_INCREMENT=56 DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='通知通告';

-- ----------------------------
--  Records of `oa_notify`
-- ----------------------------
BEGIN;
INSERT INTO `oa_notify` VALUES ('41', '3', '十九大召开了nian', '十九大召开了，竟然没邀请我', '', '1', '1', null, null, '2017-10-10 17:21:11', '', null), ('42', '3', '苹果发布新手机了', '有全面屏的iphoneX', '', '1', '1', null, null, '2017-10-10 18:51:14', '', null), ('43', '3', '十九大要消灭贫困人口', '我还只有两三年的活头了', '', '1', '1', null, null, '2017-10-11 09:56:35', '', null), ('44', '3', '骑士又输了', '捉急', '', '1', '1', null, null, '2017-10-26 13:59:34', '', null), ('52', '2', '1', '1', '1', '1', '1', null, null, '2018-01-05 14:05:47', '12', '0'), ('53', '1', '2', '2', '2', '1', '1', null, null, '2018-01-05 14:06:17', '2', '0'), ('54', '1', '3', '3', '3', null, '1', null, null, '2018-01-05 14:24:27', '3', '0'), ('55', '3', '明天周末', '明天放假', null, '1', '1', null, null, '2018-01-05 14:31:50', '222', '0');
COMMIT;

-- ----------------------------
--  Table structure for `oa_notify_record`
-- ----------------------------
DROP TABLE IF EXISTS `oa_notify_record`;
CREATE TABLE `oa_notify_record` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '编号',
  `notify_id` bigint(20) DEFAULT NULL COMMENT '通知通告ID',
  `user_id` bigint(20) DEFAULT NULL COMMENT '接受人',
  `is_read` tinyint(1) DEFAULT '0' COMMENT '阅读标记',
  `read_date` date DEFAULT NULL COMMENT '阅读时间',
  PRIMARY KEY (`id`),
  KEY `oa_notify_record_notify_id` (`notify_id`),
  KEY `oa_notify_record_user_id` (`user_id`),
  KEY `oa_notify_record_read_flag` (`is_read`)
) ENGINE=InnoDB AUTO_INCREMENT=61 DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='通知通告发送记录';

-- ----------------------------
--  Records of `oa_notify_record`
-- ----------------------------
BEGIN;
INSERT INTO `oa_notify_record` VALUES ('18', '41', '1', '1', '2017-10-26'), ('19', '42', '1', '1', '2017-10-26'), ('20', '43', '136', '0', null), ('21', '43', '133', '0', null), ('22', '43', '130', '0', null), ('23', '43', '1', '1', '2017-10-26'), ('24', '44', '1', '1', '2017-12-24'), ('25', '53', '134', '0', null), ('26', '53', '1', '1', '2018-01-05'), ('27', '53', '2', '0', null), ('28', '53', '36', '0', null), ('29', '53', '123', '0', null), ('30', '53', '124', '0', null), ('31', '53', '131', '0', null), ('32', '53', '135', '0', null), ('33', '53', '130', '0', null), ('34', '53', '136', '0', null), ('35', '53', '132', '0', null), ('36', '53', '11', '0', null), ('37', '54', '134', '0', null), ('38', '54', '1', '1', '2018-01-05'), ('39', '54', '2', '0', null), ('40', '54', '36', '0', null), ('41', '54', '123', '0', null), ('42', '54', '124', '0', null), ('43', '54', '131', '0', null), ('44', '54', '135', '0', null), ('45', '54', '130', '0', null), ('46', '54', '136', '0', null), ('47', '54', '132', '0', null), ('48', '54', '11', '0', null), ('49', '55', '134', '0', null), ('50', '55', '1', '0', null), ('51', '55', '2', '0', null), ('52', '55', '36', '0', null), ('53', '55', '123', '0', null), ('54', '55', '124', '0', null), ('55', '55', '131', '0', null), ('56', '55', '135', '0', null), ('57', '55', '130', '0', null), ('58', '55', '136', '0', null), ('59', '55', '132', '0', null), ('60', '55', '11', '0', null);
COMMIT;

-- ----------------------------
--  Table structure for `salary`
-- ----------------------------
DROP TABLE IF EXISTS `salary`;
CREATE TABLE `salary` (
  `id` varchar(64) COLLATE utf8_bin NOT NULL COMMENT '编号',
  `PROC_INS_ID` varchar(64) COLLATE utf8_bin DEFAULT NULL COMMENT '流程实例ID',
  `USER_ID` varchar(64) COLLATE utf8_bin DEFAULT NULL COMMENT '变动用户',
  `OFFICE_ID` varchar(64) COLLATE utf8_bin DEFAULT NULL COMMENT '归属部门',
  `POST` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '岗位',
  `AGE` char(1) COLLATE utf8_bin DEFAULT NULL COMMENT '性别',
  `EDU` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '学历',
  `CONTENT` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '调整原因',
  `OLDA` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '现行标准 薪酬档级',
  `OLDB` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '现行标准 月工资额',
  `OLDC` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '现行标准 年薪总额',
  `NEWA` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '调整后标准 薪酬档级',
  `NEWB` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '调整后标准 月工资额',
  `NEWC` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '调整后标准 年薪总额',
  `ADD_NUM` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '月增资',
  `EXE_DATE` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '执行时间',
  `HR_TEXT` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '人力资源部门意见',
  `LEAD_TEXT` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '分管领导意见',
  `MAIN_LEAD_TEXT` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '集团主要领导意见',
  `create_by` varchar(64) COLLATE utf8_bin NOT NULL COMMENT '创建者',
  `create_date` datetime NOT NULL COMMENT '创建时间',
  `update_by` varchar(64) COLLATE utf8_bin NOT NULL COMMENT '更新者',
  `update_date` datetime NOT NULL COMMENT '更新时间',
  `remarks` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '备注信息',
  `del_flag` char(1) COLLATE utf8_bin NOT NULL DEFAULT '0' COMMENT '删除标记',
  PRIMARY KEY (`id`),
  KEY `OA_TEST_AUDIT_del_flag` (`del_flag`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='审批流程测试表';

-- ----------------------------
--  Records of `salary`
-- ----------------------------
BEGIN;
INSERT INTO `salary` VALUES ('a80e1d9ef35a4502bd65b0e5ba7eafff', '', 'cccc', 'ccc', 'ccccc', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '2017-11-30 16:35:15', '', '2017-11-30 16:35:15', '', ''), ('b5d228f729f74833883917825749f0d5', '', '', '', '', '', '', '', '', '', '', '', '', '防守打法', '', '', '', '', '', '', '2017-11-30 19:58:36', '', '2017-11-30 19:58:36', '', ''), ('cc2e8083f9d8478f831b2ea852e5c17b', '', '', 'cc', 'cc', '', '', 'xxx', '', '', '', '', '', '', '', '', '', '', '', '', '2017-11-30 19:18:59', '', '2017-11-30 19:18:59', '', ''), ('cebdb316794b48be87d93dd4dbfb7d4b', '', '', '', '发的顺丰', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '2017-11-30 19:58:43', '', '2017-11-30 19:58:43', '', '');
COMMIT;

-- ----------------------------
--  Table structure for `sys_config`
-- ----------------------------
DROP TABLE IF EXISTS `sys_config`;
CREATE TABLE `sys_config` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  `k` varchar(100) DEFAULT NULL COMMENT '键',
  `v` varchar(1000) DEFAULT NULL COMMENT '值',
  `remark` varchar(100) DEFAULT NULL COMMENT '备注',
  `create_time` datetime DEFAULT NULL COMMENT '创建时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

-- ----------------------------
--  Records of `sys_config`
-- ----------------------------
BEGIN;
INSERT INTO `sys_config` VALUES ('2', 'oss_qiniu', '{\n\"AccessKey\" : \"8-HMj9EgGNIP-xuOCpSzTn-OMyGOFtR3TxLdn4Uu\",\n\"SecretKey\" : \"SjpGg3V6PsMdJgn42PeEd5Ik-6aNyuwdqV5CPM6A\",\n\"bucket\" : \"ifast\",\n\"AccessUrl\" : \"http://p6r7ke2jc.bkt.clouddn.com/\"\n}', '七牛对象存储配置', '2018-04-06 14:31:26');
COMMIT;

-- ----------------------------
--  Table structure for `sys_dept`
-- ----------------------------
DROP TABLE IF EXISTS `sys_dept`;
CREATE TABLE `sys_dept` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `parent_id` bigint(20) DEFAULT NULL COMMENT '上级部门ID，一级部门为0',
  `name` varchar(50) DEFAULT NULL COMMENT '部门名称',
  `order_num` int(11) DEFAULT NULL COMMENT '排序',
  `del_flag` tinyint(4) DEFAULT '0' COMMENT '是否删除  -1：已删除  0：正常',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=17 DEFAULT CHARSET=utf8 COMMENT='部门管理';

-- ----------------------------
--  Records of `sys_dept`
-- ----------------------------
BEGIN;
INSERT INTO `sys_dept` VALUES ('6', '0', '研发部', '1', '1'), ('7', '6', '研发一部', '1', '1'), ('8', '6', '研发二部', '2', '1'), ('9', '0', '销售部', '2', '1'), ('11', '0', '产品部', '3', '1'), ('12', '11', '产品一部', '1', '1'), ('13', '0', '测试部', '5', '1'), ('14', '13', '测试一部', '1', '1'), ('15', '13', '测试二部', '2', '1'), ('16', '9', '销售一部', '0', '1');
COMMIT;

-- ----------------------------
--  Table structure for `sys_dict`
-- ----------------------------
DROP TABLE IF EXISTS `sys_dict`;
CREATE TABLE `sys_dict` (
  `id` bigint(64) NOT NULL AUTO_INCREMENT COMMENT '编号',
  `name` varchar(100) COLLATE utf8_bin DEFAULT NULL COMMENT '标签名',
  `value` varchar(100) COLLATE utf8_bin DEFAULT NULL COMMENT '数据值',
  `type` varchar(100) COLLATE utf8_bin DEFAULT NULL COMMENT '类型',
  `description` varchar(100) COLLATE utf8_bin DEFAULT NULL COMMENT '描述',
  `sort` decimal(10,0) DEFAULT NULL COMMENT '排序（升序）',
  `parent_id` bigint(64) DEFAULT '0' COMMENT '父级编号',
  `create_by` int(64) DEFAULT NULL COMMENT '创建者',
  `create_date` datetime DEFAULT NULL COMMENT '创建时间',
  `update_by` bigint(64) DEFAULT NULL COMMENT '更新者',
  `update_date` datetime DEFAULT NULL COMMENT '更新时间',
  `remarks` varchar(255) COLLATE utf8_bin DEFAULT NULL COMMENT '备注信息',
  `del_flag` char(1) COLLATE utf8_bin DEFAULT '0' COMMENT '删除标记',
  PRIMARY KEY (`id`),
  KEY `sys_dict_value` (`value`),
  KEY `sys_dict_label` (`name`),
  KEY `sys_dict_del_flag` (`del_flag`)
) ENGINE=InnoDB AUTO_INCREMENT=121 DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='字典表';

-- ----------------------------
--  Records of `sys_dict`
-- ----------------------------
BEGIN;
INSERT INTO `sys_dict` VALUES ('1', '正常', '0', 'del_flag', '删除标记', '10', '0', '1', null, '1', null, null, '0'), ('3', '显示', '1', 'show_hide', '显示/隐藏', '10', '0', '1', null, '1', null, null, '0'), ('4', '隐藏', '0', 'show_hide', '显示/隐藏', '20', '0', '1', null, '1', null, null, '0'), ('5', '是', '1', 'yes_no', '是/否', '10', '0', '1', null, '1', null, null, '0'), ('6', '否', '0', 'yes_no', '是/否', '20', '0', '1', null, '1', null, null, '0'), ('7', '红色', 'red', 'color', '颜色值', '10', '0', '1', null, '1', null, null, '0'), ('8', '绿色', 'green', 'color', '颜色值', '20', '0', '1', null, '1', null, null, '0'), ('9', '蓝色', 'blue', 'color', '颜色值', '30', '0', '1', null, '1', null, null, '0'), ('10', '黄色', 'yellow', 'color', '颜色值', '40', '0', '1', null, '1', null, null, '0'), ('11', '橙色', 'orange', 'color', '颜色值', '50', '0', '1', null, '1', null, null, '0'), ('12', '默认主题', 'default', 'theme', '主题方案', '10', '0', '1', null, '1', null, null, '0'), ('13', '天蓝主题', 'cerulean', 'theme', '主题方案', '20', '0', '1', null, '1', null, null, '0'), ('14', '橙色主题', 'readable', 'theme', '主题方案', '30', '0', '1', null, '1', null, null, '0'), ('15', '红色主题', 'united', 'theme', '主题方案', '40', '0', '1', null, '1', null, null, '0'), ('16', 'Flat主题', 'flat', 'theme', '主题方案', '60', '0', '1', null, '1', null, null, '0'), ('17', '国家', '1', 'sys_area_type', '区域类型', '10', '0', '1', null, '1', null, null, '0'), ('18', '省份、直辖市', '2', 'sys_area_type', '区域类型', '20', '0', '1', null, '1', null, null, '0'), ('19', '地市', '3', 'sys_area_type', '区域类型', '30', '0', '1', null, '1', null, null, '0'), ('20', '区县', '4', 'sys_area_type', '区域类型', '40', '0', '1', null, '1', null, null, '0'), ('21', '公司', '1', 'sys_office_type', '机构类型', '60', '0', '1', null, '1', null, null, '0'), ('22', '部门', '2', 'sys_office_type', '机构类型', '70', '0', '1', null, '1', null, null, '0'), ('23', '小组', '3', 'sys_office_type', '机构类型', '80', '0', '1', null, '1', null, null, '0'), ('24', '其它', '4', 'sys_office_type', '机构类型', '90', '0', '1', null, '1', null, null, '0'), ('25', '综合部', '1', 'sys_office_common', '快捷通用部门', '30', '0', '1', null, '1', null, null, '0'), ('26', '开发部', '2', 'sys_office_common', '快捷通用部门', '40', '0', '1', null, '1', null, null, '0'), ('27', '人力部', '3', 'sys_office_common', '快捷通用部门', '50', '0', '1', null, '1', null, null, '0'), ('28', '一级', '1', 'sys_office_grade', '机构等级', '10', '0', '1', null, '1', null, null, '0'), ('29', '二级', '2', 'sys_office_grade', '机构等级', '20', '0', '1', null, '1', null, null, '0'), ('30', '三级', '3', 'sys_office_grade', '机构等级', '30', '0', '1', null, '1', null, null, '0'), ('31', '四级', '4', 'sys_office_grade', '机构等级', '40', '0', '1', null, '1', null, null, '0'), ('32', '所有数据', '1', 'sys_data_scope', '数据范围', '10', '0', '1', null, '1', null, null, '0'), ('33', '所在公司及以下数据', '2', 'sys_data_scope', '数据范围', '20', '0', '1', null, '1', null, null, '0'), ('34', '所在公司数据', '3', 'sys_data_scope', '数据范围', '30', '0', '1', null, '1', null, null, '0'), ('35', '所在部门及以下数据', '4', 'sys_data_scope', '数据范围', '40', '0', '1', null, '1', null, null, '0'), ('36', '所在部门数据', '5', 'sys_data_scope', '数据范围', '50', '0', '1', null, '1', null, null, '0'), ('37', '仅本人数据', '8', 'sys_data_scope', '数据范围', '90', '0', '1', null, '1', null, null, '0'), ('38', '按明细设置', '9', 'sys_data_scope', '数据范围', '100', '0', '1', null, '1', null, null, '0'), ('39', '系统管理', '1', 'sys_user_type', '用户类型', '10', '0', '1', null, '1', null, null, '0'), ('40', '部门经理', '2', 'sys_user_type', '用户类型', '20', '0', '1', null, '1', null, null, '0'), ('41', '普通用户', '3', 'sys_user_type', '用户类型', '30', '0', '1', null, '1', null, null, '0'), ('42', '基础主题', 'basic', 'cms_theme', '站点主题', '10', '0', '1', null, '1', null, null, '0'), ('43', '蓝色主题', 'blue', 'cms_theme', '站点主题', '20', '0', '1', null, '1', null, null, '1'), ('44', '红色主题', 'red', 'cms_theme', '站点主题', '30', '0', '1', null, '1', null, null, '1'), ('45', '文章模型', 'article', 'cms_module', '栏目模型', '10', '0', '1', null, '1', null, null, '0'), ('46', '图片模型', 'picture', 'cms_module', '栏目模型', '20', '0', '1', null, '1', null, null, '1'), ('47', '下载模型', 'download', 'cms_module', '栏目模型', '30', '0', '1', null, '1', null, null, '1'), ('48', '链接模型', 'link', 'cms_module', '栏目模型', '40', '0', '1', null, '1', null, null, '0'), ('49', '专题模型', 'special', 'cms_module', '栏目模型', '50', '0', '1', null, '1', null, null, '1'), ('50', '默认展现方式', '0', 'cms_show_modes', '展现方式', '10', '0', '1', null, '1', null, null, '0'), ('51', '首栏目内容列表', '1', 'cms_show_modes', '展现方式', '20', '0', '1', null, '1', null, null, '0'), ('52', '栏目第一条内容', '2', 'cms_show_modes', '展现方式', '30', '0', '1', null, '1', null, null, '0'), ('53', '发布', '0', 'cms_del_flag', '内容状态', '10', '0', '1', null, '1', null, null, '0'), ('54', '删除', '1', 'cms_del_flag', '内容状态', '20', '0', '1', null, '1', null, null, '0'), ('55', '审核', '2', 'cms_del_flag', '内容状态', '15', '0', '1', null, '1', null, null, '0'), ('56', '首页焦点图', '1', 'cms_posid', '推荐位', '10', '0', '1', null, '1', null, null, '0'), ('57', '栏目页文章推荐', '2', 'cms_posid', '推荐位', '20', '0', '1', null, '1', null, null, '0'), ('58', '咨询', '1', 'cms_guestbook', '留言板分类', '10', '0', '1', null, '1', null, null, '0'), ('59', '建议', '2', 'cms_guestbook', '留言板分类', '20', '0', '1', null, '1', null, null, '0'), ('60', '投诉', '3', 'cms_guestbook', '留言板分类', '30', '0', '1', null, '1', null, null, '0'), ('61', '其它', '4', 'cms_guestbook', '留言板分类', '40', '0', '1', null, '1', null, null, '0'), ('62', '公休', '1', 'oa_leave_type', '请假类型', '10', '0', '1', null, '1', null, null, '0'), ('63', '病假', '2', 'oa_leave_type', '请假类型', '20', '0', '1', null, '1', null, null, '0'), ('64', '事假', '3', 'oa_leave_type', '请假类型', '30', '0', '1', null, '1', null, null, '0'), ('65', '调休', '4', 'oa_leave_type', '请假类型', '40', '0', '1', null, '1', null, null, '0'), ('66', '婚假', '5', 'oa_leave_type', '请假类型', '60', '0', '1', null, '1', null, null, '0'), ('67', '接入日志', '1', 'sys_log_type', '日志类型', '30', '0', '1', null, '1', null, null, '0'), ('68', '异常日志', '2', 'sys_log_type', '日志类型', '40', '0', '1', null, '1', null, null, '0'), ('69', '请假流程', 'leave', 'act_type', '流程类型', '10', '0', '1', null, '1', null, null, '0'), ('70', '审批测试流程', 'test_audit', 'act_type', '流程类型', '20', '0', '1', null, '1', null, null, '0'), ('71', '分类1', '1', 'act_category', '流程分类', '10', '0', '1', null, '1', null, null, '0'), ('72', '分类2', '2', 'act_category', '流程分类', '20', '0', '1', null, '1', null, null, '0'), ('73', '增删改查', 'crud', 'gen_category', '代码生成分类', '10', '0', '1', null, '1', null, null, '1'), ('74', '增删改查（包含从表）', 'crud_many', 'gen_category', '代码生成分类', '20', '0', '1', null, '1', null, null, '1'), ('75', '树结构', 'tree', 'gen_category', '代码生成分类', '30', '0', '1', null, '1', null, null, '1'), ('76', '=', '=', 'gen_query_type', '查询方式', '10', '0', '1', null, '1', null, null, '1'), ('77', '!=', '!=', 'gen_query_type', '查询方式', '20', '0', '1', null, '1', null, null, '1'), ('78', '&gt;', '&gt;', 'gen_query_type', '查询方式', '30', '0', '1', null, '1', null, null, '1'), ('79', '&lt;', '&lt;', 'gen_query_type', '查询方式', '40', '0', '1', null, '1', null, null, '1'), ('80', 'Between', 'between', 'gen_query_type', '查询方式', '50', '0', '1', null, '1', null, null, '1'), ('81', 'Like', 'like', 'gen_query_type', '查询方式', '60', '0', '1', null, '1', null, null, '1'), ('82', 'Left Like', 'left_like', 'gen_query_type', '查询方式', '70', '0', '1', null, '1', null, null, '1'), ('83', 'Right Like', 'right_like', 'gen_query_type', '查询方式', '80', '0', '1', null, '1', null, null, '1'), ('84', '文本框', 'input', 'gen_show_type', '字段生成方案', '10', '0', '1', null, '1', null, null, '1'), ('85', '文本域', 'textarea', 'gen_show_type', '字段生成方案', '20', '0', '1', null, '1', null, null, '1'), ('86', '下拉框', 'select', 'gen_show_type', '字段生成方案', '30', '0', '1', null, '1', null, null, '1'), ('87', '复选框', 'checkbox', 'gen_show_type', '字段生成方案', '40', '0', '1', null, '1', null, null, '1'), ('88', '单选框', 'radiobox', 'gen_show_type', '字段生成方案', '50', '0', '1', null, '1', null, null, '1'), ('89', '日期选择', 'dateselect', 'gen_show_type', '字段生成方案', '60', '0', '1', null, '1', null, null, '1'), ('90', '人员选择', 'userselect', 'gen_show_type', '字段生成方案', '70', '0', '1', null, '1', null, null, '1'), ('91', '部门选择', 'officeselect', 'gen_show_type', '字段生成方案', '80', '0', '1', null, '1', null, null, '1'), ('92', '区域选择', 'areaselect', 'gen_show_type', '字段生成方案', '90', '0', '1', null, '1', null, null, '1'), ('93', 'String', 'String', 'gen_java_type', 'Java类型', '10', '0', '1', null, '1', null, null, '1'), ('94', 'Long', 'Long', 'gen_java_type', 'Java类型', '20', '0', '1', null, '1', null, null, '1'), ('95', '仅持久层', 'dao', 'gen_category', '代码生成分类\0\0', '40', '0', '1', null, '1', null, null, '1'), ('96', '男', '1', 'sex', '性别', '10', '0', '1', null, '1', null, null, '0'), ('97', '女', '2', 'sex', '性别', '20', '0', '1', null, '1', null, null, '0'), ('98', 'Integer', 'Integer', 'gen_java_type', 'Java类型', '30', '0', '1', null, '1', null, null, '1'), ('99', 'Double', 'Double', 'gen_java_type', 'Java类型', '40', '0', '1', null, '1', null, null, '1'), ('100', 'Date', 'java.util.Date', 'gen_java_type', 'Java类型', '50', '0', '1', null, '1', null, null, '1'), ('104', 'Custom', 'Custom', 'gen_java_type', 'Java类型', '90', '0', '1', null, '1', null, null, '1'), ('105', '会议通告', '1', 'oa_notify_type', '通知通告类型', '10', '0', '1', null, '1', null, null, '0'), ('106', '奖惩通告', '2', 'oa_notify_type', '通知通告类型', '20', '0', '1', null, '1', null, null, '0'), ('107', '活动通告', '3', 'oa_notify_type', '通知通告类型', '30', '0', '1', null, '1', null, null, '0'), ('108', '草稿', '0', 'oa_notify_status', '通知通告状态', '10', '0', '1', null, '1', null, null, '0'), ('109', '发布', '1', 'oa_notify_status', '通知通告状态', '20', '0', '1', null, '1', null, null, '0'), ('110', '未读', '0', 'oa_notify_read', '通知通告状态', '10', '0', '1', null, '1', null, null, '0'), ('111', '已读', '1', 'oa_notify_read', '通知通告状态', '20', '0', '1', null, '1', null, null, '0'), ('112', '草稿', '0', 'oa_notify_status', '通知通告状态', '10', '0', '1', null, '1', null, '', '0'), ('113', '删除', '0', 'del_flag', '删除标记', null, null, null, null, null, null, '', ''), ('118', '关于', 'about', 'blog_type', '博客类型', null, null, null, null, null, null, '全url是:/blog/open/page/about', ''), ('119', '交流', 'communication', 'blog_type', '博客类型', null, null, null, null, null, null, '', ''), ('120', '文章', 'article', 'blog_type', '博客类型', null, null, null, null, null, null, '', '');
COMMIT;

-- ----------------------------
--  Table structure for `sys_file`
-- ----------------------------
DROP TABLE IF EXISTS `sys_file`;
CREATE TABLE `sys_file` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `type` int(11) DEFAULT NULL COMMENT '文件类型',
  `url` varchar(200) DEFAULT NULL COMMENT 'URL地址',
  `create_date` datetime DEFAULT NULL COMMENT '创建时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=152 DEFAULT CHARSET=utf8 COMMENT='文件上传';

-- ----------------------------
--  Records of `sys_file`
-- ----------------------------
BEGIN;
INSERT INTO `sys_file` VALUES ('140', '0', 'http://p6r7ke2jc.bkt.clouddn.com/ifast/20180406/cat003.jpeg', '2018-04-06 17:58:03'), ('141', '0', 'http://p6r7ke2jc.bkt.clouddn.com/ifast/20180406/cat002-1523009188140.jpeg', '2018-04-06 18:06:28'), ('148', '0', 'http://p6r7ke2jc.bkt.clouddn.com/ifast/20180406/cd09920f-7d51-4c60-a3a1-c36c83b3dfb4-1523028484072.png', '2018-04-06 23:28:05');
COMMIT;

-- ----------------------------
--  Table structure for `sys_log`
-- ----------------------------
DROP TABLE IF EXISTS `sys_log`;
CREATE TABLE `sys_log` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `user_id` bigint(20) DEFAULT NULL COMMENT '用户id',
  `username` varchar(50) DEFAULT NULL COMMENT '用户名',
  `operation` varchar(50) DEFAULT NULL COMMENT '用户操作',
  `time` int(11) DEFAULT NULL COMMENT '响应时间',
  `method` varchar(200) DEFAULT NULL COMMENT '请求方法',
  `params` varchar(5000) DEFAULT NULL COMMENT '请求参数',
  `ip` varchar(64) DEFAULT NULL COMMENT 'IP地址',
  `gmt_create` datetime DEFAULT NULL COMMENT '创建时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=8846 DEFAULT CHARSET=utf8 COMMENT='系统日志';

-- ----------------------------
--  Records of `sys_log`
-- ----------------------------
BEGIN;
INSERT INTO `sys_log` VALUES ('8600', '1', 'admin', '请求访问主页', '8', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 22:51:10'), ('8601', '1', 'admin', '请求访问主页', '6', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:05:26'), ('8602', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-27 23:09:49'), ('8603', '1', 'admin', '请求访问主页', '10', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:09:49'), ('8604', '1', 'admin', '请求访问主页', '6', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:12:03'), ('8605', '1', 'admin', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:12:13'), ('8606', '1', 'admin', '请求访问主页', '6', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:14:33'), ('8607', '1', 'admin', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:14:53'), ('8608', '1', 'admin', '登录', '8', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-27 23:16:28'), ('8609', '1', 'admin', '请求访问主页', '32', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:16:28'), ('8610', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-27 23:20:22'), ('8611', '1', 'admin', '请求访问主页', '13', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:20:22'), ('8612', '1', 'admin', '请求访问主页', '7', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:23:34'), ('8613', '1', 'admin', '登录', '8', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-27 23:31:08'), ('8614', '1', 'admin', '请求访问主页', '26', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:31:08'), ('8615', '1', 'admin', '请求访问主页', '10', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:31:25'), ('8616', '1', 'admin', '请求访问主页', '7', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:33:25'), ('8617', '1', 'admin', '登录', '7', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-27 23:34:05'), ('8618', '1', 'admin', '请求访问主页', '30', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:34:05'), ('8619', '1', 'admin', '登录', '10', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-27 23:38:46'), ('8620', '1', 'admin', '请求访问主页', '30', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:38:46'), ('8621', '1', 'admin', '登录', '9', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-27 23:42:09'), ('8622', '1', 'admin', '请求访问主页', '31', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:42:09'), ('8623', '1', 'admin', '登录', '4', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-27 23:43:35'), ('8624', '1', 'admin', '请求访问主页', '16', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:43:35'), ('8625', '1', 'admin', '请求访问主页', '7', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:44:47'), ('8626', '1', 'admin', '请求访问主页', '7', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:47:11'), ('8627', '1', 'admin', '请求访问主页', '6', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:49:07'), ('8628', '1', 'admin', '请求访问主页', '7', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-27 23:53:17'), ('8629', '1', 'admin', '登录', '13', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-29 18:03:08'), ('8630', '1', 'admin', '请求访问主页', '59', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-29 18:03:08'), ('8631', '1', 'admin', '登录', '12', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-31 13:44:02'), ('8632', '1', 'admin', '请求访问主页', '55', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-31 13:44:02'), ('8633', '1', 'admin', '登录', '8', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-31 14:13:51'), ('8634', '1', 'admin', '请求访问主页', '44', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-31 14:13:51'), ('8635', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-31 16:29:02'), ('8636', '1', 'admin', '请求访问主页', '9', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-31 16:29:02'), ('8637', '1', 'admin', '添加角色', '0', 'com.ifast.sys.controller.RoleController.add()', null, '127.0.0.1', '2018-03-31 16:29:19'), ('8638', '1', 'admin', '保存角色', '18', 'com.ifast.sys.controller.RoleController.save()', null, '127.0.0.1', '2018-03-31 16:31:25'), ('8639', '1', 'admin', '添加用户', '2', 'com.ifast.sys.controller.UserController.add()', null, '127.0.0.1', '2018-03-31 16:31:33'), ('8640', '1', 'admin', '保存用户', '16', 'com.ifast.sys.controller.UserController.save()', null, '127.0.0.1', '2018-03-31 16:32:15'), ('8641', '137', 'sign123', '登录', '1', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-31 16:32:26'), ('8642', '137', 'sign123', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-31 16:32:26'), ('8643', '1', 'admin', '登录', '1', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-31 16:32:49'), ('8644', '1', 'admin', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-31 16:32:49'), ('8645', '1', 'admin', '编辑角色', '3', 'com.ifast.sys.controller.RoleController.edit()', null, '127.0.0.1', '2018-03-31 16:33:01'), ('8646', '1', 'admin', '更新角色', '12', 'com.ifast.sys.controller.RoleController.update()', null, '127.0.0.1', '2018-03-31 16:33:08'), ('8647', '137', 'sign123', '登录', '2', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-31 16:33:18'), ('8648', '137', 'sign123', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-31 16:33:18'), ('8649', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-31 16:33:56'), ('8650', '1', 'admin', '请求访问主页', '4', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-31 16:33:56'), ('8651', '1', 'admin', '编辑角色', '2', 'com.ifast.sys.controller.RoleController.edit()', null, '127.0.0.1', '2018-03-31 16:34:02'), ('8652', '1', 'admin', '更新角色', '7', 'com.ifast.sys.controller.RoleController.update()', null, '127.0.0.1', '2018-03-31 16:34:12'), ('8653', '137', 'sign123', '登录', '2', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-31 16:34:24'), ('8654', '137', 'sign123', '请求访问主页', '4', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-31 16:34:24'), ('8655', '137', 'sign123', '请求访问主页', '9', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-31 16:36:25'), ('8656', '1', 'admin', '登录', '7', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-31 16:57:35'), ('8657', '1', 'admin', '请求访问主页', '46', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-31 16:57:35'), ('8658', '1', 'admin', '登录', '9', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-03-31 18:19:05'), ('8659', '1', 'admin', '请求访问主页', '45', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-03-31 18:19:05'), ('8660', '1', 'admin', '登录', '9', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 00:12:27'), ('8661', '1', 'admin', '请求访问主页', '25', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 00:12:27'), ('8662', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 00:21:54'), ('8663', '1', 'admin', '请求访问主页', '11', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 00:21:54'), ('8664', '1', 'admin', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 00:23:29'), ('8665', '1', 'admin', '登录', '7', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 02:00:06'), ('8666', '1', 'admin', '请求访问主页', '22', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 02:00:06'), ('8667', '1', 'admin', '登录', '2', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 03:08:48'), ('8668', '1', 'admin', '请求访问主页', '12', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 03:08:48'), ('8669', '1', 'admin', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 03:13:48'), ('8670', '1', 'admin', '请求访问主页', '4', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 03:14:08'), ('8671', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 03:18:26'), ('8672', '1', 'admin', '请求访问主页', '9', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 03:18:26'), ('8673', '1', 'admin', '登录', '8', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 03:19:52'), ('8674', '1', 'admin', '请求访问主页', '47', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 03:19:53'), ('8675', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 03:22:13'), ('8676', '1', 'admin', '请求访问主页', '13', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 03:22:13'), ('8677', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 03:25:08'), ('8678', '1', 'admin', '请求访问主页', '12', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 03:25:08'), ('8679', '-1', '获取用户信息为空', '登录', '6', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 05:12:45'), ('8680', '137', 'sign123', '登录', '7', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 05:12:54'), ('8681', '137', 'sign123', '请求访问主页', '21', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 05:12:54'), ('8682', '137', 'sign123', '登录', '11', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 05:15:47'), ('8683', '137', 'sign123', '请求访问主页', '39', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 05:15:47'), ('8684', '137', 'sign123', '登录', '2', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 05:33:27'), ('8685', '137', 'sign123', '请求访问主页', '8', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 05:33:27'), ('8686', '1', 'admin', '登录', '13', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 18:25:54'), ('8687', '1', 'admin', '请求访问主页', '27', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 18:25:54'), ('8688', '1', 'admin', '登录', '8', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 18:38:55'), ('8689', '1', 'admin', '请求访问主页', '23', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 18:38:55'), ('8690', '1', 'admin', '请求访问主页', '10', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 18:39:01'), ('8691', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 18:42:00'), ('8692', '1', 'admin', '请求访问主页', '11', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 18:42:00'), ('8693', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 18:42:20'), ('8694', '1', 'admin', '请求访问主页', '12', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 18:42:20'), ('8695', '1', 'admin', '登录', '8', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 19:41:30'), ('8696', '1', 'admin', '请求访问主页', '45', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 19:41:30'), ('8697', '1', 'admin', '请求访问主页', '9', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 19:43:06'), ('8698', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 19:45:37'), ('8699', '1', 'admin', '请求访问主页', '14', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 19:45:37'), ('8700', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 19:47:01'), ('8701', '1', 'admin', '请求访问主页', '14', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 19:47:01'), ('8702', '1', 'admin', '登录', '12', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 19:48:12'), ('8703', '1', 'admin', '请求访问主页', '54', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 19:48:12'), ('8704', '1', 'admin', '登录', '4', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 19:54:45'), ('8705', '1', 'admin', '请求访问主页', '14', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 19:54:45'), ('8706', '1', 'admin', '登录', '9', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 21:41:51'), ('8707', '1', 'admin', '请求访问主页', '26', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 21:41:51'), ('8708', '137', 'sign123', '登录', '20', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-01 21:59:12'), ('8709', '137', 'sign123', '请求访问主页', '98', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-01 21:59:12'), ('8710', '-1', '获取用户信息为空', '登录', '5', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-04 20:19:24'), ('8711', '1', 'admin', '登录', '6', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-04 20:19:27'), ('8712', '1', 'admin', '请求访问主页', '51', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:19:27'), ('8713', '1', 'admin', '登录', '8', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-04 20:33:35'), ('8714', '1', 'admin', '请求访问主页', '49', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:33:35'), ('8715', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-04 20:34:16'), ('8716', '1', 'admin', '请求访问主页', '8', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:34:16'), ('8717', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-04 20:36:25'), ('8718', '1', 'admin', '请求访问主页', '15', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:36:25'), ('8719', '1', 'admin', '请求访问主页', '11', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:41:04'), ('8720', '1', 'admin', '编辑角色', '2', 'com.ifast.sys.controller.RoleController.edit()', null, '127.0.0.1', '2018-04-04 20:41:25'), ('8721', '1', 'admin', '更新角色', '21', 'com.ifast.sys.controller.RoleController.update()', null, '127.0.0.1', '2018-04-04 20:41:58'), ('8722', '1', 'admin', '请求访问主页', '9', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:42:01'), ('8723', '1', 'admin', '请求访问主页', '6', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:44:57'), ('8724', '1', 'admin', '请求访问主页', '12', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:45:56'), ('8725', '1', 'admin', '登录', '4', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-04 20:47:46'), ('8726', '1', 'admin', '请求访问主页', '11', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:47:46'), ('8727', '1', 'admin', '请求访问主页', '7', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:49:42'), ('8728', '1', 'admin', '请求访问主页', '16', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:51:37'), ('8729', '1', 'admin', '请求访问主页', '7', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:55:55'), ('8730', '1', 'admin', '编辑菜单', '3', 'com.ifast.sys.controller.MenuController.edit()', null, '127.0.0.1', '2018-04-04 20:56:34'), ('8731', '1', 'admin', '更新菜单', '6', 'com.ifast.sys.controller.MenuController.update()', null, '127.0.0.1', '2018-04-04 20:56:45'), ('8732', '1', 'admin', '编辑菜单', '2', 'com.ifast.sys.controller.MenuController.edit()', null, '127.0.0.1', '2018-04-04 20:56:54'), ('8733', '1', 'admin', '更新菜单', '4', 'com.ifast.sys.controller.MenuController.update()', null, '127.0.0.1', '2018-04-04 20:57:05'), ('8734', '1', 'admin', '编辑菜单', '2', 'com.ifast.sys.controller.MenuController.edit()', null, '127.0.0.1', '2018-04-04 20:57:16'), ('8735', '1', 'admin', '编辑菜单', '3', 'com.ifast.sys.controller.MenuController.edit()', null, '127.0.0.1', '2018-04-04 20:57:21'), ('8736', '1', 'admin', '更新菜单', '3', 'com.ifast.sys.controller.MenuController.update()', null, '127.0.0.1', '2018-04-04 20:57:36'), ('8737', '1', 'admin', '编辑菜单', '2', 'com.ifast.sys.controller.MenuController.edit()', null, '127.0.0.1', '2018-04-04 20:57:45'), ('8738', '1', 'admin', '更新菜单', '4', 'com.ifast.sys.controller.MenuController.update()', null, '127.0.0.1', '2018-04-04 20:57:59'), ('8739', '1', 'admin', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:58:37'), ('8740', '1', 'admin', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-04 20:59:08'), ('8741', '1', 'admin', '登录', '8', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-05 13:18:04'), ('8742', '1', 'admin', '请求访问主页', '58', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-05 13:18:04'), ('8743', '1', 'admin', '编辑角色', '2', 'com.ifast.sys.controller.RoleController.edit()', null, '127.0.0.1', '2018-04-05 13:21:16'), ('8744', '1', 'admin', '更新角色', '19', 'com.ifast.sys.controller.RoleController.update()', null, '127.0.0.1', '2018-04-05 13:21:30'), ('8745', '1', 'admin', '删除角色', '8', 'com.ifast.sys.controller.RoleController.save()', null, '127.0.0.1', '2018-04-05 13:21:38'), ('8746', '1', 'admin', '登录', '8', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-05 13:31:32'), ('8747', '1', 'admin', '请求访问主页', '47', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-05 13:31:32'), ('8748', '1', 'admin', '登录', '9', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-05 13:37:39'), ('8749', '1', 'admin', '请求访问主页', '46', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-05 13:37:39'), ('8750', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-05 13:40:16'), ('8751', '1', 'admin', '请求访问主页', '15', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-05 13:40:16'), ('8752', '1', 'admin', '登录', '8', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-05 13:42:30'), ('8753', '1', 'admin', '请求访问主页', '49', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-05 13:42:30'), ('8754', '1', 'admin', '请求访问主页', '12', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-05 13:43:42'), ('8755', '1', 'admin', '更新用户', '15', 'com.ifast.sys.controller.UserController.updatePeronal()', null, '127.0.0.1', '2018-04-05 13:45:42'), ('8756', '1', 'admin', '更新用户', '5', 'com.ifast.sys.controller.UserController.updatePeronal()', null, '127.0.0.1', '2018-04-05 13:47:27'), ('8757', '1', 'admin', '更新用户', '4', 'com.ifast.sys.controller.UserController.updatePeronal()', null, '127.0.0.1', '2018-04-05 13:47:41'), ('8758', '1', 'admin', '更新用户', '5', 'com.ifast.sys.controller.UserController.updatePeronal()', null, '127.0.0.1', '2018-04-05 13:47:54'), ('8759', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-05 13:48:54'), ('8760', '1', 'admin', '请求访问主页', '14', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-05 13:48:54'), ('8761', '1', 'admin', '更新用户', '5', 'com.ifast.sys.controller.UserController.updatePeronal()', null, '127.0.0.1', '2018-04-05 13:49:08'), ('8762', '1', 'admin', '更新用户', '4', 'com.ifast.sys.controller.UserController.updatePeronal()', null, '127.0.0.1', '2018-04-05 13:49:25'), ('8763', '1', 'admin', '请求访问主页', '10', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-05 13:51:12'), ('8764', '1', 'admin', '更新用户', '6', 'com.ifast.sys.controller.UserController.updatePeronal()', null, '127.0.0.1', '2018-04-05 13:52:41'), ('8765', '1', 'admin', '更新用户', '31040', 'com.ifast.sys.controller.UserController.updatePeronal()', null, '127.0.0.1', '2018-04-05 13:53:50'), ('8766', '1', 'admin', '更新用户', '5764', 'com.ifast.sys.controller.UserController.updatePeronal()', null, '127.0.0.1', '2018-04-05 13:54:44'), ('8767', '1', 'admin', '更新用户', '3830', 'com.ifast.sys.controller.UserController.updatePeronal()', null, '127.0.0.1', '2018-04-05 13:56:00'), ('8768', '1', 'admin', '更新用户', '5', 'com.ifast.sys.controller.UserController.updatePeronal()', null, '127.0.0.1', '2018-04-05 13:57:48'), ('8769', '1', 'admin', '请求访问主页', '7', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-05 13:59:00'), ('8770', '1', 'admin', '登录', '9', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-05 20:33:52'), ('8771', '1', 'admin', '请求访问主页', '56', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-05 20:33:52'), ('8772', '1', 'admin', '编辑用户', '25', 'com.ifast.sys.controller.UserController.edit()', null, '127.0.0.1', '2018-04-05 20:40:26'), ('8773', '1', 'admin', '登录', '42', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 00:48:13'), ('8774', '1', 'admin', '请求访问主页', '38', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 00:48:13'), ('8775', '-1', '获取用户信息为空', '登录', '2', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 00:48:18'), ('8776', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 00:48:22'), ('8777', '1', 'admin', '请求访问主页', '8', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 00:48:22'), ('8778', '1', 'admin', '请求更改用户密码', '0', 'com.ifast.sys.controller.UserController.resetPwd()', null, '127.0.0.1', '2018-04-06 00:48:56'), ('8779', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 01:04:14'), ('8780', '1', 'admin', '请求访问主页', '10', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 01:04:14'), ('8781', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 01:05:09'), ('8782', '1', 'admin', '请求访问主页', '9', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 01:05:09'), ('8783', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 01:07:55'), ('8784', '1', 'admin', '请求访问主页', '8', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 01:07:55'), ('8785', '1', 'admin', '编辑菜单', '3', 'com.ifast.sys.controller.MenuController.edit()', null, '127.0.0.1', '2018-04-06 01:08:10'), ('8786', '1', 'admin', '更新菜单', '13', 'com.ifast.sys.controller.MenuController.update()', null, '127.0.0.1', '2018-04-06 01:08:24'), ('8787', '1', 'admin', '编辑角色', '3', 'com.ifast.sys.controller.RoleController.edit()', null, '127.0.0.1', '2018-04-06 01:08:34'), ('8788', '1', 'admin', '更新角色', '12', 'com.ifast.sys.controller.RoleController.update()', null, '127.0.0.1', '2018-04-06 01:08:41'), ('8789', '1', 'admin', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 01:08:42'), ('8790', '1', 'admin', '登录', '1', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 01:08:58'), ('8791', '1', 'admin', '请求访问主页', '4', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 01:08:58'), ('8792', '1', 'admin', '登录', '9', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 01:11:27'), ('8793', '1', 'admin', '请求访问主页', '46', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 01:11:27'), ('8794', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 13:29:47'), ('8795', '1', 'admin', '请求访问主页', '10', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 13:29:47'), ('8796', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 13:30:39'), ('8797', '1', 'admin', '请求访问主页', '11', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 13:30:39'), ('8798', '1', 'admin', '请求访问主页', '7', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 13:33:36'), ('8799', '1', 'admin', '登录', '9', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 17:56:09'), ('8800', '1', 'admin', '请求访问主页', '46', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 17:56:09'), ('8801', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 17:57:11'), ('8802', '1', 'admin', '请求访问主页', '13', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 17:57:11'), ('8803', '1', 'admin', '请求访问主页', '6', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 17:57:26'), ('8804', '1', 'admin', '登录', '10', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 18:06:17'), ('8805', '1', 'admin', '请求访问主页', '41', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 18:06:18'), ('8806', '1', 'admin', '登录', '13', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 18:11:35'), ('8807', '1', 'admin', '请求访问主页', '43', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 18:11:36'), ('8808', '1', 'admin', '登录', '8', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 18:25:10'), ('8809', '1', 'admin', '请求访问主页', '45', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 18:25:10'), ('8810', '1', 'admin', '请求访问主页', '7', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 18:25:39'), ('8811', '1', 'admin', '登录', '2', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 18:25:43'), ('8812', '1', 'admin', '请求访问主页', '6', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 18:25:43'), ('8813', '1', 'admin', '登录', '2', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 18:28:43'), ('8814', '1', 'admin', '请求访问主页', '11', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 18:28:43'), ('8815', '1', 'admin', '登录', '2', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 18:28:56'), ('8816', '1', 'admin', '请求访问主页', '6', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 18:28:56'), ('8817', '1', 'admin', '请求访问主页', '6', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 18:28:57'), ('8818', '1', 'admin', '请求访问主页', '4', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 18:30:46'), ('8819', '1', 'admin', '登录', '9', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 23:22:18'), ('8820', '1', 'admin', '请求访问主页', '43', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 23:22:18'), ('8821', '1', 'admin', '登录', '4', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 23:27:50'), ('8822', '1', 'admin', '请求访问主页', '12', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 23:27:50'), ('8823', '1', 'admin', '请求访问主页', '11', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 23:28:07'), ('8824', '1', 'admin', '登录', '2', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 23:28:14'), ('8825', '1', 'admin', '请求访问主页', '8', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 23:28:14'), ('8826', '1', 'admin', '登录', '2', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 23:29:04'), ('8827', '1', 'admin', '请求访问主页', '9', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 23:29:04'), ('8828', '1', 'admin', '登录', '1', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 23:29:54'), ('8829', '1', 'admin', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 23:29:54'), ('8830', '1', 'admin', '编辑用户', '8', 'com.ifast.sys.controller.UserController.edit()', null, '127.0.0.1', '2018-04-06 23:31:25'), ('8831', '1', 'admin', '请求访问主页', '7', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 23:33:06'), ('8832', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-06 23:33:54'), ('8833', '1', 'admin', '请求访问主页', '5', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-06 23:33:54'), ('8834', '1', 'admin', '登录', '12', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-07 00:07:35'), ('8835', '1', 'admin', '请求访问主页', '42', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-07 00:07:36'), ('8836', '1', 'admin', '登录', '9', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-07 23:49:38'), ('8837', '1', 'admin', '请求访问主页', '51', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-07 23:49:38'), ('8838', '1', 'admin', '登录', '3', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-07 23:49:54'), ('8839', '1', 'admin', '请求访问主页', '11', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-07 23:49:54'), ('8840', '1', 'admin', '请求访问主页', '11', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-07 23:50:43'), ('8841', '1', 'admin', '请求访问主页', '10', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-07 23:50:59'), ('8842', '1', 'admin', '登录', '13', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-08 18:10:31'), ('8843', '1', 'admin', '请求访问主页', '53', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-08 18:10:31'), ('8844', '1', 'admin', '登录', '14', 'com.ifast.sys.controller.LoginController.ajaxLogin()', null, '127.0.0.1', '2018-04-08 22:11:24'), ('8845', '1', 'admin', '请求访问主页', '43', 'com.ifast.sys.controller.LoginController.index()', null, '127.0.0.1', '2018-04-08 22:11:24');
COMMIT;

-- ----------------------------
--  Table structure for `sys_menu`
-- ----------------------------
DROP TABLE IF EXISTS `sys_menu`;
CREATE TABLE `sys_menu` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `parent_id` bigint(20) DEFAULT NULL COMMENT '父菜单ID，一级菜单为0',
  `name` varchar(50) DEFAULT NULL COMMENT '菜单名称',
  `url` varchar(200) DEFAULT NULL COMMENT '菜单URL',
  `perms` varchar(500) DEFAULT NULL COMMENT '授权(多个用逗号分隔，如：user:list,user:create)',
  `type` int(11) DEFAULT NULL COMMENT '类型   0：目录   1：菜单   2：按钮',
  `icon` varchar(50) DEFAULT NULL COMMENT '菜单图标',
  `order_num` int(11) DEFAULT NULL COMMENT '排序',
  `gmt_create` datetime DEFAULT NULL COMMENT '创建时间',
  `gmt_modified` datetime DEFAULT NULL COMMENT '修改时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=181 DEFAULT CHARSET=utf8 COMMENT='菜单管理';

-- ----------------------------
--  Records of `sys_menu`
-- ----------------------------
BEGIN;
INSERT INTO `sys_menu` VALUES ('1', '0', '基础管理', '', '', '0', 'fa fa-bars', '0', '2017-08-09 22:49:47', null), ('2', '3', '系统菜单', 'sys/menu/', 'sys:menu:menu', '1', 'fa fa-th-list', '2', '2017-08-09 22:55:15', null), ('3', '0', '系统管理', null, null, '0', 'fa fa-desktop', '1', '2017-08-09 23:06:55', '2017-08-14 14:13:43'), ('6', '3', '用户管理', 'sys/user/', 'sys:user:user', '1', 'fa fa-user', '0', '2017-08-10 14:12:11', null), ('7', '3', '角色管理', 'sys/role', 'sys:role:role', '1', 'fa fa-paw', '1', '2017-08-10 14:13:19', null), ('12', '6', '新增', '', 'sys:user:add', '2', '', '0', '2017-08-14 10:51:35', null), ('13', '6', '编辑', '', 'sys:user:edit', '2', '', '0', '2017-08-14 10:52:06', null), ('14', '6', '删除', null, 'sys:user:remove', '2', null, '0', '2017-08-14 10:52:24', null), ('15', '7', '新增', '', 'sys:role:add', '2', '', '0', '2017-08-14 10:56:37', null), ('20', '2', '新增', '', 'sys:menu:add', '2', '', '0', '2017-08-14 10:59:32', null), ('21', '2', '编辑', '', 'sys:menu:edit', '2', '', '0', '2017-08-14 10:59:56', null), ('22', '2', '删除', '', 'sys:menu:remove', '2', '', '0', '2017-08-14 11:00:26', null), ('24', '6', '批量删除', '', 'sys:user:batchRemove', '2', '', '0', '2017-08-14 17:27:18', null), ('25', '6', '停用', null, 'sys:user:disable', '2', null, '0', '2017-08-14 17:27:43', null), ('26', '6', '重置密码', '', 'sys:user:resetPwd', '2', '', '0', '2017-08-14 17:28:34', null), ('27', '91', '系统日志', 'common/log', 'common:log', '1', 'fa fa-warning', '0', '2017-08-14 22:11:53', null), ('28', '27', '刷新', null, 'sys:log:list', '2', null, '0', '2017-08-14 22:30:22', null), ('29', '27', '删除', null, 'sys:log:remove', '2', null, '0', '2017-08-14 22:30:43', null), ('30', '27', '清空', null, 'sys:log:clear', '2', null, '0', '2017-08-14 22:31:02', null), ('48', '77', '代码生成', 'common/generator', 'common:generator', '1', 'fa fa-code', '3', null, null), ('55', '7', '编辑', '', 'sys:role:edit', '2', '', null, null, null), ('56', '7', '删除', '', 'sys:role:remove', '2', null, null, null, null), ('57', '91', '运行监控', '/druid/index.html', '', '1', 'fa fa-caret-square-o-right', '1', null, null), ('61', '2', '批量删除', '', 'sys:menu:batchRemove', '2', null, null, null, null), ('62', '7', '批量删除', '', 'sys:role:batchRemove', '2', null, null, null, null), ('71', '1', '文件管理', '/common/sysFile', 'common:sysFile:sysFile', '1', 'fa fa-folder-open', '2', null, null), ('72', '77', '计划任务', 'common/job', 'common:taskScheduleJob', '1', 'fa fa-hourglass-1', '4', null, null), ('73', '3', '部门管理', '/sys/dept', 'system:sysDept:sysDept', '1', 'fa fa-users', '3', null, null), ('74', '73', '增加', '/sys/dept/add', 'system:sysDept:add', '2', null, '1', null, null), ('75', '73', '刪除', 'sys/dept/remove', 'system:sysDept:remove', '2', null, '2', null, null), ('76', '73', '编辑', '/sys/dept/edit', 'system:sysDept:edit', '2', null, '3', null, null), ('77', '0', '系统工具', '', '', '0', 'fa fa-gear', '4', null, null), ('78', '1', '数据字典', '/common/sysDict', 'common:sysDict:sysDict', '1', 'fa fa-book', '1', null, null), ('79', '78', '增加', '/common/sysDict/add', 'common:sysDict:add', '2', null, '2', null, null), ('80', '78', '编辑', '/common/sysDict/edit', 'common:sysDict:edit', '2', null, '2', null, null), ('81', '78', '删除', '/common/sysDict/remove', 'common:sysDict:remove', '2', '', '3', null, null), ('83', '78', '批量删除', '/common/sysDict/batchRemove', 'common:sysDict:batchRemove', '2', '', '4', null, null), ('91', '0', '系统监控', '', '', '0', 'fa fa-video-camera', '5', null, null), ('92', '91', '在线用户', 'sys/online', '', '1', 'fa fa-user', null, null, null), ('97', '0', '图表管理', '', '', '0', 'fa fa-bar-chart', '7', null, null), ('98', '97', '百度chart', '/chart/graph_echarts.html', '', '1', 'fa fa-area-chart', null, null, null), ('151', '1', '公司信息管理', '/sign/appCompany', null, '1', 'fa fa-file-code-o', '6', null, null), ('152', '151', '查看', null, 'sign:appCompany:appCompany', '2', null, '6', null, null), ('153', '151', '新增', null, 'sign:appCompany:add', '2', null, '6', null, null), ('154', '151', '修改', null, 'sign:appCompany:edit', '2', null, '6', null, null), ('155', '151', '删除', null, 'sign:appCompany:remove', '2', null, '6', null, null), ('156', '151', '批量删除', null, 'sign:appCompany:batchRemove', '2', null, '6', null, null), ('157', '1', '出差管理', '/sign/appOutWork', null, '1', 'fa fa-file-code-o', '6', null, null), ('158', '157', '查看', null, 'sign:appOutWork:appOutWork', '2', null, '6', null, null), ('159', '157', '新增', null, 'sign:appOutWork:add', '2', null, '6', null, null), ('160', '157', '修改', null, 'sign:appOutWork:edit', '2', null, '6', null, null), ('161', '157', '删除', null, 'sign:appOutWork:remove', '2', null, '6', null, null), ('162', '157', '批量删除', null, 'sign:appOutWork:batchRemove', '2', null, '6', null, null), ('163', '1', '考勤管理', '/sign/appSign', null, '1', 'fa fa-file-code-o', '6', null, null), ('164', '163', '查看', null, 'sign:appSign:appSign', '2', null, '6', null, null), ('165', '163', '新增', null, 'sign:appSign:add', '2', null, '6', null, null), ('166', '163', '修改', null, 'sign:appSign:edit', '2', null, '6', null, null), ('167', '163', '删除', null, 'sign:appSign:remove', '2', null, '6', null, null), ('168', '163', '批量删除', null, 'sign:appSign:batchRemove', '2', null, '6', null, null), ('169', '1', '员工管理', '/sign/appUser', null, '1', 'fa fa-file-code-o', '6', null, null), ('170', '169', '查看', null, 'sign:appUser:appUser', '2', null, '6', null, null), ('171', '169', '新增', null, 'sign:appUser:add', '2', null, '6', null, null), ('172', '169', '修改', null, 'sign:appUser:edit', '2', null, '6', null, null), ('173', '169', '删除', null, 'sign:appUser:remove', '2', null, '6', null, null), ('174', '169', '批量删除', null, 'sign:appUser:batchRemove', '2', null, '6', null, null), ('175', '1', '系统配置', '/common/config', null, '1', 'fa fa-file-code-o', '6', null, null), ('176', '175', '查看', null, 'common:config:config', '2', null, '6', null, null), ('177', '175', '新增', null, 'common:config:add', '2', null, '6', null, null), ('178', '175', '修改', null, 'common:config:edit', '2', null, '6', null, null), ('179', '175', '删除', null, 'common:config:remove', '2', null, '6', null, null), ('180', '175', '批量删除', null, 'common:config:batchRemove', '2', null, '6', null, null);
COMMIT;

-- ----------------------------
--  Table structure for `sys_role`
-- ----------------------------
DROP TABLE IF EXISTS `sys_role`;
CREATE TABLE `sys_role` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `role_name` varchar(100) DEFAULT NULL COMMENT '角色名称',
  `role_sign` varchar(100) DEFAULT NULL COMMENT '角色标识',
  `remark` varchar(100) DEFAULT NULL COMMENT '备注',
  `user_id_create` bigint(255) DEFAULT NULL COMMENT '创建用户id',
  `gmt_create` datetime DEFAULT NULL COMMENT '创建时间',
  `gmt_modified` datetime DEFAULT NULL COMMENT '创建时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=58 DEFAULT CHARSET=utf8 COMMENT='角色';

-- ----------------------------
--  Records of `sys_role`
-- ----------------------------
BEGIN;
INSERT INTO `sys_role` VALUES ('1', '超级用户角色', 'admin', '超级管理员', '2', '2017-08-12 00:43:52', '2017-08-12 19:14:59'), ('56', '普通用户', null, '普通用户', null, null, null), ('57', '签到系统', null, null, null, null, null);
COMMIT;

-- ----------------------------
--  Table structure for `sys_role_menu`
-- ----------------------------
DROP TABLE IF EXISTS `sys_role_menu`;
CREATE TABLE `sys_role_menu` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `role_id` bigint(20) DEFAULT NULL COMMENT '角色ID',
  `menu_id` bigint(20) DEFAULT NULL COMMENT '菜单ID',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4308 DEFAULT CHARSET=utf8 COMMENT='角色与菜单对应关系';

-- ----------------------------
--  Records of `sys_role_menu`
-- ----------------------------
BEGIN;
INSERT INTO `sys_role_menu` VALUES ('367', '44', '1'), ('368', '44', '32'), ('369', '44', '33'), ('370', '44', '34'), ('371', '44', '35'), ('372', '44', '28'), ('373', '44', '29'), ('374', '44', '30'), ('375', '44', '38'), ('376', '44', '4'), ('377', '44', '27'), ('378', '45', '38'), ('379', '46', '3'), ('380', '46', '20'), ('381', '46', '21'), ('382', '46', '22'), ('383', '46', '23'), ('384', '46', '11'), ('385', '46', '12'), ('386', '46', '13'), ('387', '46', '14'), ('388', '46', '24'), ('389', '46', '25'), ('390', '46', '26'), ('391', '46', '15'), ('392', '46', '2'), ('393', '46', '6'), ('394', '46', '7'), ('598', '50', '38'), ('632', '38', '42'), ('737', '51', '38'), ('738', '51', '39'), ('739', '51', '40'), ('740', '51', '41'), ('741', '51', '4'), ('742', '51', '32'), ('743', '51', '33'), ('744', '51', '34'), ('745', '51', '35'), ('746', '51', '27'), ('747', '51', '28'), ('748', '51', '29'), ('749', '51', '30'), ('750', '51', '1'), ('1064', '54', '53'), ('1095', '55', '2'), ('1096', '55', '6'), ('1097', '55', '7'), ('1098', '55', '3'), ('1099', '55', '50'), ('1100', '55', '49'), ('1101', '55', '1'), ('1856', '53', '28'), ('1857', '53', '29'), ('1858', '53', '30'), ('1859', '53', '27'), ('1860', '53', '57'), ('1861', '53', '71'), ('1862', '53', '48'), ('1863', '53', '72'), ('1864', '53', '1'), ('1865', '53', '7'), ('1866', '53', '55'), ('1867', '53', '56'), ('1868', '53', '62'), ('1869', '53', '15'), ('1870', '53', '2'), ('1871', '53', '61'), ('1872', '53', '20'), ('1873', '53', '21'), ('1874', '53', '22'), ('2247', '63', '-1'), ('2248', '63', '84'), ('2249', '63', '85'), ('2250', '63', '88'), ('2251', '63', '87'), ('2252', '64', '84'), ('2253', '64', '89'), ('2254', '64', '88'), ('2255', '64', '87'), ('2256', '64', '86'), ('2257', '64', '85'), ('2258', '65', '89'), ('2259', '65', '88'), ('2260', '65', '86'), ('2262', '67', '48'), ('2263', '68', '88'), ('2264', '68', '87'), ('2265', '69', '89'), ('2266', '69', '88'), ('2267', '69', '86'), ('2268', '69', '87'), ('2269', '69', '85'), ('2270', '69', '84'), ('2271', '70', '85'), ('2272', '70', '89'), ('2273', '70', '88'), ('2274', '70', '87'), ('2275', '70', '86'), ('2276', '70', '84'), ('2277', '71', '87'), ('2278', '72', '59'), ('2279', '73', '48'), ('2280', '74', '88'), ('2281', '74', '87'), ('2282', '75', '88'), ('2283', '75', '87'), ('2284', '76', '85'), ('2285', '76', '89'), ('2286', '76', '88'), ('2287', '76', '87'), ('2288', '76', '86'), ('2289', '76', '84'), ('2292', '78', '88'), ('2293', '78', '87'), ('2294', '78', null), ('2295', '78', null), ('2296', '78', null), ('2308', '80', '87'), ('2309', '80', '86'), ('2310', '80', '-1'), ('2311', '80', '84'), ('2312', '80', '85'), ('2328', '79', '72'), ('2329', '79', '48'), ('2330', '79', '77'), ('2331', '79', '84'), ('2332', '79', '89'), ('2333', '79', '88'), ('2334', '79', '87'), ('2335', '79', '86'), ('2336', '79', '85'), ('2337', '79', '-1'), ('2338', '77', '89'), ('2339', '77', '88'), ('2340', '77', '87'), ('2341', '77', '86'), ('2342', '77', '85'), ('2343', '77', '84'), ('2344', '77', '72'), ('2345', '77', '-1'), ('2346', '77', '77'), ('3178', '56', '68'), ('3179', '56', '60'), ('3180', '56', '59'), ('3181', '56', '58'), ('3182', '56', '51'), ('3183', '56', '50'), ('3184', '56', '49'), ('3185', '56', '-1'), ('4146', '57', '79'), ('4147', '57', '80'), ('4148', '57', '152'), ('4149', '57', '153'), ('4150', '57', '154'), ('4151', '57', '155'), ('4152', '57', '156'), ('4153', '57', '158'), ('4154', '57', '159'), ('4155', '57', '160'), ('4156', '57', '161'), ('4157', '57', '162'), ('4158', '57', '164'), ('4159', '57', '165'), ('4160', '57', '166'), ('4161', '57', '167'), ('4162', '57', '168'), ('4163', '57', '170'), ('4164', '57', '171'), ('4165', '57', '172'), ('4166', '57', '173'), ('4167', '57', '174'), ('4168', '57', '28'), ('4169', '57', '29'), ('4170', '57', '30'), ('4171', '57', '57'), ('4172', '57', '92'), ('4173', '57', '151'), ('4174', '57', '157'), ('4175', '57', '163'), ('4176', '57', '169'), ('4177', '57', '27'), ('4178', '57', '91'), ('4179', '57', '-1'), ('4180', '57', '1'), ('4181', '57', '78'), ('4262', '1', '71'), ('4263', '1', '79'), ('4264', '1', '80'), ('4265', '1', '81'), ('4266', '1', '83'), ('4267', '1', '20'), ('4268', '1', '21'), ('4269', '1', '22'), ('4270', '1', '61'), ('4271', '1', '12'), ('4272', '1', '13'), ('4273', '1', '14'), ('4274', '1', '24'), ('4275', '1', '25'), ('4276', '1', '26'), ('4277', '1', '15'), ('4278', '1', '55'), ('4279', '1', '56'), ('4280', '1', '62'), ('4281', '1', '74'), ('4282', '1', '75'), ('4283', '1', '76'), ('4284', '1', '48'), ('4285', '1', '72'), ('4286', '1', '28'), ('4287', '1', '29'), ('4288', '1', '30'), ('4289', '1', '57'), ('4290', '1', '92'), ('4291', '1', '78'), ('4292', '1', '2'), ('4293', '1', '6'), ('4294', '1', '7'), ('4295', '1', '73'), ('4296', '1', '3'), ('4297', '1', '77'), ('4298', '1', '27'), ('4299', '1', '91'), ('4300', '1', '175'), ('4301', '1', '176'), ('4302', '1', '177'), ('4303', '1', '178'), ('4304', '1', '179'), ('4305', '1', '180'), ('4306', '1', '-1'), ('4307', '1', '1');
COMMIT;

-- ----------------------------
--  Table structure for `sys_task`
-- ----------------------------
DROP TABLE IF EXISTS `sys_task`;
CREATE TABLE `sys_task` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `cron_expression` varchar(255) DEFAULT NULL COMMENT 'cron表达式',
  `method_name` varchar(255) DEFAULT NULL COMMENT '任务调用的方法名',
  `is_concurrent` varchar(255) DEFAULT NULL COMMENT '任务是否有状态',
  `description` varchar(255) DEFAULT NULL COMMENT '任务描述',
  `update_by` varchar(64) DEFAULT NULL COMMENT '更新者',
  `bean_class` varchar(255) DEFAULT NULL COMMENT '任务执行时调用哪个类的方法 包名+类名',
  `create_date` datetime DEFAULT NULL COMMENT '创建时间',
  `job_status` varchar(255) DEFAULT NULL COMMENT '任务状态',
  `job_group` varchar(255) DEFAULT NULL COMMENT '任务分组',
  `update_date` datetime DEFAULT NULL COMMENT '更新时间',
  `create_by` varchar(64) DEFAULT NULL COMMENT '创建者',
  `spring_bean` varchar(255) DEFAULT NULL COMMENT 'Spring bean',
  `job_name` varchar(255) DEFAULT NULL COMMENT '任务名',
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=9 DEFAULT CHARSET=utf8;

-- ----------------------------
--  Records of `sys_task`
-- ----------------------------
BEGIN;
INSERT INTO `sys_task` VALUES ('2', '0/10 * * * * ?', 'run1', '1', '', '4028ea815a3d2a8c015a3d2f8d2a0002', 'com.ifast.job.TestJob', '2017-05-19 18:30:56', '0', 'group1', '2017-05-19 18:31:07', null, '', 'TestJob');
COMMIT;

-- ----------------------------
--  Table structure for `sys_user`
-- ----------------------------
DROP TABLE IF EXISTS `sys_user`;
CREATE TABLE `sys_user` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `username` varchar(50) DEFAULT NULL COMMENT '用户名',
  `name` varchar(100) DEFAULT NULL,
  `password` varchar(50) DEFAULT NULL COMMENT '密码',
  `dept_id` bigint(20) DEFAULT NULL,
  `email` varchar(100) DEFAULT NULL COMMENT '邮箱',
  `mobile` varchar(100) DEFAULT NULL COMMENT '手机号',
  `status` tinyint(255) DEFAULT NULL COMMENT '状态 0:禁用，1:正常',
  `user_id_create` bigint(255) DEFAULT NULL COMMENT '创建用户id',
  `gmt_create` datetime DEFAULT NULL COMMENT '创建时间',
  `gmt_modified` datetime DEFAULT NULL COMMENT '修改时间',
  `sex` bigint(32) DEFAULT NULL COMMENT '性别',
  `birth` datetime DEFAULT NULL COMMENT '出身日期',
  `pic_id` bigint(32) DEFAULT NULL,
  `live_address` varchar(500) DEFAULT NULL COMMENT '现居住地',
  `hobby` varchar(255) DEFAULT NULL COMMENT '爱好',
  `province` varchar(255) DEFAULT NULL COMMENT '省份',
  `city` varchar(255) DEFAULT NULL COMMENT '所在城市',
  `district` varchar(255) DEFAULT NULL COMMENT '所在地区',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=138 DEFAULT CHARSET=utf8;

-- ----------------------------
--  Records of `sys_user`
-- ----------------------------
BEGIN;
INSERT INTO `sys_user` VALUES ('1', 'admin', '超级管理员', '33808479d49ca8a3cdc93d4f976d1e3d', '6', 'izenglong@163.com', '15277778888', '1', '1', '2017-08-15 21:40:39', '2017-08-15 21:41:00', '96', '2018-04-02 00:00:00', '151', '创客基地', null, '广东省', '广州市', '番禺区'), ('2', 'test', '临时用户', 'b132f5f968c9373261f74025c23c2222', '6', 'test@bootdo.com', null, '1', '1', '2017-08-14 13:43:05', '2017-08-14 21:15:36', null, null, null, null, null, null, null, null), ('36', 'ldh', '刘德华', 'bfd9394475754fbe45866eba97738c36', '6', 'ldh@bootdo.com1', null, '1', null, null, null, null, null, null, null, null, null, null, null), ('123', 'zxy', '张学友', '35174ba93f5fe7267f1fb3c1bf903781', '6', 'zxy@bootdo', null, '0', null, null, null, null, null, null, null, null, null, null, null), ('124', 'wyf', '吴亦凡', 'e179e6f687bbd57b9d7efc4746c8090a', '6', 'wyf@bootdo.com', null, '1', null, null, null, null, null, null, null, null, null, null, null), ('130', 'lh', '鹿晗', '7924710cd673f68967cde70e188bb097', '9', 'lh@bootdo.com', null, '1', null, null, null, null, null, null, null, null, null, null, null), ('131', 'lhc', '令狐冲', 'd515538e17ecb570ba40344b5618f5d4', '6', 'lhc@bootdo.com', null, '0', null, null, null, null, null, null, null, null, null, null, null), ('132', 'lyf', '刘亦菲', '7fdb1d9008f45950c1620ba0864e5fbd', '13', 'lyf@bootdo.com', null, '1', null, null, null, null, null, null, null, null, null, null, null), ('134', 'lyh', '李彦宏', 'dc26092b3244d9d432863f2738180e19', '8', 'lyh@bootdo.com', null, '1', null, null, null, null, null, null, null, null, null, null, null), ('135', 'wjl', '王健林', '3967697dfced162cf6a34080259b83aa', '6', 'wjl@bootod.com', null, '1', null, null, null, null, null, null, null, null, null, null, null), ('136', 'gdg', '郭德纲', '3bb1bda86bc02bf6478cd91e42135d2f', '9', 'gdg@bootdo.com1', null, '1', null, null, null, null, null, null, null, null, null, null, null), ('137', 'sign123', 'sign123', '1e3d9b9fb85ecfc0041f5b944e6a7854', '15', 'sign@sign.com', null, '1', null, null, null, null, null, null, null, null, null, null, null);
COMMIT;

-- ----------------------------
--  Table structure for `sys_user_role`
-- ----------------------------
DROP TABLE IF EXISTS `sys_user_role`;
CREATE TABLE `sys_user_role` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `user_id` bigint(20) DEFAULT NULL COMMENT '用户ID',
  `role_id` bigint(20) DEFAULT NULL COMMENT '角色ID',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=132 DEFAULT CHARSET=utf8 COMMENT='用户与角色对应关系';

-- ----------------------------
--  Records of `sys_user_role`
-- ----------------------------
BEGIN;
INSERT INTO `sys_user_role` VALUES ('73', '30', '48'), ('74', '30', '49'), ('75', '30', '50'), ('76', '31', '48'), ('77', '31', '49'), ('78', '31', '52'), ('79', '32', '48'), ('80', '32', '49'), ('81', '32', '50'), ('82', '32', '51'), ('83', '32', '52'), ('84', '33', '38'), ('85', '33', '49'), ('86', '33', '52'), ('87', '34', '50'), ('88', '34', '51'), ('89', '34', '52'), ('106', '124', '1'), ('110', '1', '1'), ('111', '2', '1'), ('113', '131', '48'), ('117', '135', '1'), ('120', '134', '1'), ('121', '134', '48'), ('123', '130', '1'), ('124', null, '48'), ('125', '132', '52'), ('126', '132', '49'), ('127', null, '1'), ('128', null, '1'), ('129', null, '1'), ('130', '36', '48'), ('131', '137', '57');
COMMIT;

-- ----------------------------
--  Table structure for `wx_mp_config`
-- ----------------------------
DROP TABLE IF EXISTS `wx_mp_config`;
CREATE TABLE `wx_mp_config` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  `token` varchar(120) DEFAULT NULL,
  `app_id` varchar(64) NOT NULL COMMENT 'APPID',
  `app_secret` varchar(128) NOT NULL COMMENT 'AppSecret',
  `msg_mode` int(11) DEFAULT NULL COMMENT '1加密 0不加密',
  `msg_secret` varchar(128) DEFAULT NULL,
  `mp_name` varchar(250) DEFAULT NULL COMMENT '公众号名字',
  `app_type` int(11) NOT NULL COMMENT '公众号类型： 1.订阅号 2.服务号 3.企业号 4.小程序 5. 测试号',
  `is_auth` int(11) DEFAULT NULL COMMENT '认证授权：1已认证 0未认证',
  `subscribe_url` varchar(500) DEFAULT NULL COMMENT '提示订阅URL',
  `app_key` varchar(100) DEFAULT NULL COMMENT '开放的公众号key',
  `logo` varchar(255) DEFAULT NULL,
  `create_time` datetime NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8mb4 COMMENT='微信配置表';

-- ----------------------------
--  Records of `wx_mp_config`
-- ----------------------------
BEGIN;
INSERT INTO `wx_mp_config` VALUES ('10', 'weixin', 'wx4c2c55425d476e48', 'f1849eedf5d2bbbe9fcb2caaa71f6cb1', '0', 'LiUJz8XMKhBH4wh40VwgLsSwFdHCGTmEj4VK3T71SkL', '源码在线', '2', '0', 'http://xxx.com', 'ymh', 'http://wx.qlogo.cn/mmopen/dH8QVxmk2IVAic06s166sFJOTInGwqld2JJIYQicb4pQdwsTXWTJEjeDN1BCDRsDtuDkFp6sDQy67TwaKWsTdXXGv6hGQe67UY/0', '2017-11-03 17:32:48'), ('11', '72597b9628704ab09e8b9e8cbe9b540a', 'wxeb5638d307d3df71', '03b1501c72a91f2935037336e43e67e6', '0', null, '源码在线-测试', '5', '0', 'http://xxx.com/test', 'ymhTest', null, '2017-11-03 17:32:53'), ('12', 'token_huimeitkb', 'wx4d106f4dc7aa68fe', 'f2375d2d6e38561a093dd95f1cc5726e', '0', 'WYNP4CmAsGaFABav3lvXXAz5iBJRh5UnUJvDaDZi92T', '广州灵猫', '1', '0', 'http://xxx.com/test', 'lm', null, '2017-11-03 17:32:56'), ('13', 'token_yunyoujiaxiang', 'wx2ae79bb50a968369', '7038c1a75d8e8ce35467d68613d2522a', '0', 'rzJee4cTxtEqL4pifsuaS4W6DzUHGz8BUwEWfLdxAF0', '云游佳乡-test', '2', '0', null, 'yunyoujiaxiang_test', null, '2017-11-20 11:24:26'), ('14', 'token_jiaxianghui', 'wx20e48f3aa36fadab', '512c5271f15133e951247104c09089ad', '0', 'aYtN2TxTBh3nDOv0Bn11Enw5PvQ6TLfBP4WLjD76JVi', '佳乡汇-test', '2', '0', null, 'jiaxianghui_test', null, '2017-11-20 15:12:02');
COMMIT;

-- ----------------------------
--  Table structure for `wx_mp_fans`
-- ----------------------------
DROP TABLE IF EXISTS `wx_mp_fans`;
CREATE TABLE `wx_mp_fans` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `mp_id` bigint(11) NOT NULL COMMENT '公众号id',
  `openid` varchar(100) DEFAULT NULL COMMENT '用户的标识，对当前公众号唯一',
  `nickname` varchar(100) DEFAULT NULL COMMENT '昵称',
  `subscribe` tinyint(4) DEFAULT NULL COMMENT '用户是否订阅该公众号标识，值为0时，代表此用户没有关注该公众号，拉取不到其余信息。0未关注，1已关注',
  `subscribe_time` datetime DEFAULT NULL COMMENT '用户关注时间，为时间戳。如果用户曾多次关注，则取最后关注时间',
  `subscribe_key` varchar(100) DEFAULT NULL COMMENT '关注来源',
  `sex` tinyint(4) DEFAULT NULL COMMENT '用户的性别，值为1时是男性，值为2时是女性，值为0时是未知',
  `city` varchar(100) DEFAULT NULL,
  `country` varchar(100) DEFAULT NULL,
  `province` varchar(100) DEFAULT NULL,
  `language` varchar(100) DEFAULT NULL COMMENT '语言',
  `headimgurl` varchar(500) DEFAULT NULL COMMENT '用户头像，最后一个数值代表正方形头像大小（有0、46、64、96、132数值可选，0代表640*640正方形头像），用户没有头像时该项为空。若用户更换头像，原有头像URL将失效。',
  `unionid` varchar(125) DEFAULT NULL,
  `remark` varchar(500) DEFAULT NULL COMMENT '公众号运营者对粉丝的备注，公众号运营者可在微信公众平台用户管理界面对粉丝添加备注',
  `groupid` int(20) DEFAULT NULL COMMENT '分组ID',
  `status` tinyint(11) DEFAULT NULL COMMENT '用户状态 1:正常，0：禁用',
  `tagid_list` varchar(100) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2905 DEFAULT CHARSET=utf8mb4 COMMENT='微信粉丝表';

-- ----------------------------
--  Records of `wx_mp_fans`
-- ----------------------------
BEGIN;
INSERT INTO `wx_mp_fans` VALUES ('2891', '5', 'oorK7v9q1VpB4avDq9ui8_oeGvcU', '罗恩勤-商标专利，建筑资质', '1', '2017-06-29 19:19:24', null, '1', '深圳', '中国', '广东', 'zh_CN', 'http://wx.qlogo.cn/mmopen/kWOnVmxq6fYcB7S1ULr22aWICsEyF25SvlTeRLlGCbD1laVuSCgYwnwe7f04aJl8uDpv1JFQZ0Ivq2o3ejgCDIKXWFib4OKsK/0', 'oI55m1lueqEi13WG3D3VRz3QyECE', '', '0', '0', null), ('2892', '5', 'oorK7v4LWw3GMbwt_Ck6PuQ_8_D8', '你是我的眼', '0', null, null, '2', '广州', '中国', '广东', 'zh_CN', 'http://wx.qlogo.cn/mmopen/A7sq8BD8oewx50myY72SwetEVkBXbXDvT5jj6ytorRxqyGwtBu1XTnWGohGXhdTtTwh6VSAbUEUSWpibddJDChg/0', 'oI55m1o8VxrTFvV57WkzEFTHLRIM', null, null, '0', null), ('2893', '5', 'oorK7vyBCT3WOGcc-ijmO2U4p9dM', '老丙汇客服', '0', '2017-11-01 20:02:39', null, '2', '广州', '中国', '广东', 'zh_CN', 'http://wx.qlogo.cn/mmopen/2QZKlomn2rSCSH7SWGoYnNK7wfJLq8yjxs7YR5ribPTGibw3QzMlf6nic2CJhtaAqzkOXsyJBAxhpuqD4sXNmRTibFaDy9p5VAjw/0', 'oI55m1vLSjJMqoiKjhrOpvXxdWuI', '', '0', '0', null), ('2895', '7', 'otO0P09bRa-YRLNlPbJEL1bdDjkQ', 'Aron', '1', '2017-11-24 11:14:28', '', '1', '广州', '中国', '广东', 'zh_CN', 'http://wx.qlogo.cn/mmopen/BQD9yxMcK6CicIrF6tU8Pqucb2VgYicn1iaTMTwm9war1KLT9RlibbsJ9cYal7yypERODjt6XGXC4dVJdVs9woJZBHwI0ibmaGQxY/0', 'oVzGa0kCIhSXljL9wDALjN00ylOs', '', '0', '0', null), ('2896', '7', 'otO0P08gP66AEAthpg3TnlZ6ktYA', 'Jethro Chen', null, null, null, '1', '广州', '中国', '广东', 'zh_CN', 'http://wx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTLFGLh61UCcAZHM67bLwvFCp2GG2yYlA36P16198o7nCWppmQ3QjTDYPIjT6rhjHcM6Ikm7r4nBIg/0', 'oVzGa0peHnOzSQiMeUCIQQElTiBo', null, null, null, null), ('2897', '9', 'ozbGr0vZhCS8Pe1lpTuy1tq9Wlls', 'SuSu', '0', '2017-11-26 21:03:25', '', '1', '江北', '中国', '重庆', 'zh_CN', 'http://wx.qlogo.cn/mmopen/8o7KgbIM6ibFyF3coD1mMMdm91kic6Tb68P0hq9lDccec0TllUm5MnBa4WEesfiaW1HUXWqNqCTNUsrYM5iceq9gnesbSPSaE0Yw/0', 'oJitl0bd590o0ONtSt1nB7hFh0Bo', '', '0', null, null), ('2898', '5', 'oorK7v9q1VpB4avDq9ui8_oeGvcU', '罗恩勤-商标专利，建筑资质', '1', '2017-06-29 19:19:24', null, '1', '深圳', '中国', '广东', 'zh_CN', 'http://wx.qlogo.cn/mmopen/kWOnVmxq6fYcB7S1ULr22aWICsEyF25SvlTeRLlGCbD1laVuSCgYwnwe7f04aJl8uDpv1JFQZ0Ivq2o3ejgCDIKXWFib4OKsK/0', 'oI55m1lueqEi13WG3D3VRz3QyECE', '', '0', '0', null), ('2899', '5', 'oorK7v4LWw3GMbwt_Ck6PuQ_8_D8', '你是我的眼', '0', null, null, '2', '广州', '中国', '广东', 'zh_CN', 'http://wx.qlogo.cn/mmopen/A7sq8BD8oewx50myY72SwetEVkBXbXDvT5jj6ytorRxqyGwtBu1XTnWGohGXhdTtTwh6VSAbUEUSWpibddJDChg/0', 'oI55m1o8VxrTFvV57WkzEFTHLRIM', null, null, '0', null), ('2900', '5', 'oorK7vyBCT3WOGcc-ijmO2U4p9dM', '老丙汇客服', '0', '2017-11-01 20:02:39', null, '2', '广州', '中国', '广东', 'zh_CN', 'http://wx.qlogo.cn/mmopen/2QZKlomn2rSCSH7SWGoYnNK7wfJLq8yjxs7YR5ribPTGibw3QzMlf6nic2CJhtaAqzkOXsyJBAxhpuqD4sXNmRTibFaDy9p5VAjw/0', 'oI55m1vLSjJMqoiKjhrOpvXxdWuI', '', '0', '0', null), ('2902', '7', 'otO0P09bRa-YRLNlPbJEL1bdDjkQ', 'Aron', '1', '2017-11-24 11:14:28', '', '1', '广州', '中国', '广东', 'zh_CN', 'http://wx.qlogo.cn/mmopen/BQD9yxMcK6CicIrF6tU8Pqucb2VgYicn1iaTMTwm9war1KLT9RlibbsJ9cYal7yypERODjt6XGXC4dVJdVs9woJZBHwI0ibmaGQxY/0', 'oVzGa0kCIhSXljL9wDALjN00ylOs', '', '0', '0', null), ('2903', '7', 'otO0P08gP66AEAthpg3TnlZ6ktYA', 'Jethro Chen', null, null, null, '1', '广州', '中国', '广东', 'zh_CN', 'http://wx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTLFGLh61UCcAZHM67bLwvFCp2GG2yYlA36P16198o7nCWppmQ3QjTDYPIjT6rhjHcM6Ikm7r4nBIg/0', 'oVzGa0peHnOzSQiMeUCIQQElTiBo', null, null, null, null), ('2904', '9', 'ozbGr0vZhCS8Pe1lpTuy1tq9Wlls', 'SuSu', '0', '2017-11-26 21:03:25', '', '1', '江北', '中国', '重庆', 'zh_CN', 'http://wx.qlogo.cn/mmopen/8o7KgbIM6ibFyF3coD1mMMdm91kic6Tb68P0hq9lDccec0TllUm5MnBa4WEesfiaW1HUXWqNqCTNUsrYM5iceq9gnesbSPSaE0Yw/0', 'oJitl0bd590o0ONtSt1nB7hFh0Bo', '', '0', null, null);
COMMIT;

-- ----------------------------
--  Table structure for `wx_mp_menu`
-- ----------------------------
DROP TABLE IF EXISTS `wx_mp_menu`;
CREATE TABLE `wx_mp_menu` (
  `id` bigint(11) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  `parent_idx` bigint(20) DEFAULT NULL,
  `menu_type` varchar(50) NOT NULL COMMENT '菜单类型：1主菜单，2链接，3文本，4关键字，5扫码，6发图，7发送位置',
  `menu_name` varchar(128) NOT NULL,
  `menu_key` varchar(64) DEFAULT NULL,
  `menu_url` varchar(500) DEFAULT NULL COMMENT '菜单链接',
  `reply_content` varchar(500) DEFAULT NULL,
  `scan_type` int(4) DEFAULT NULL COMMENT '扫码类型：1扫码带事件，2扫码带提示',
  `picture_type` int(4) DEFAULT NULL COMMENT '发图类型：1，系统拍照发图；2,，拍照或者相册发图；3，微信相册发图',
  `location` varchar(255) DEFAULT NULL COMMENT '发送位置',
  `sort` int(11) DEFAULT NULL COMMENT '菜单排序',
  `status` int(4) DEFAULT NULL COMMENT '菜单状态',
  `create_by` bigint(20) DEFAULT NULL COMMENT '创建人',
  `create_time` datetime DEFAULT NULL COMMENT '创建时间',
  `update_by` bigint(20) DEFAULT NULL COMMENT '更新人',
  `update_time` datetime DEFAULT NULL COMMENT '更新时间',
  `mp_id` bigint(20) NOT NULL COMMENT '微信配置ID',
  `idx` bigint(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='微信菜单表';

-- ----------------------------
--  Table structure for `wx_mp_wechat_keys`
-- ----------------------------
DROP TABLE IF EXISTS `wx_mp_wechat_keys`;
CREATE TABLE `wx_mp_wechat_keys` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `mp_id` bigint(20) NOT NULL COMMENT '公众号id',
  `media_id` varchar(50) DEFAULT NULL COMMENT '素材Id',
  `keyword` varchar(200) DEFAULT NULL COMMENT '关键字，以#,#隔开',
  `type` tinyint(4) DEFAULT NULL COMMENT '回复类型，1：关键字 2：关注自动回复 3：默认回复',
  `reply_type` varchar(20) DEFAULT NULL COMMENT '回复类型，文字：text 图文：news 图片： image 语音：voice 音乐：music 视频：video',
  `content` text COMMENT '内容',
  `news_id` bigint(20) DEFAULT NULL COMMENT '图文素材Id',
  `music_title` varchar(100) DEFAULT NULL COMMENT '音乐标题',
  `music_cover` varchar(255) DEFAULT NULL COMMENT '音乐封面',
  `music_url` varchar(255) DEFAULT NULL COMMENT '音乐url',
  `music_desc` varchar(255) DEFAULT NULL COMMENT '音乐描述',
  `image_url` varchar(255) DEFAULT NULL COMMENT '图片URL',
  `voice_url` varchar(255) DEFAULT NULL COMMENT '音频URL',
  `video_title` varchar(100) DEFAULT NULL COMMENT '视频标题',
  `video_url` varchar(255) DEFAULT NULL COMMENT '视频url',
  `video_desc` varchar(255) DEFAULT NULL COMMENT '视频描述',
  `create_time` datetime DEFAULT NULL COMMENT '创建时间',
  `update_time` datetime DEFAULT NULL COMMENT '更新时间',
  `status` tinyint(4) NOT NULL DEFAULT '1' COMMENT '状态 0：禁用 1：启用',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='微信-关键字回复';

SET FOREIGN_KEY_CHECKS = 1;
